Here’s a clean and structured explanation of LEFT JOIN and RIGHT JOIN using tables in a readable way:
Understanding LEFT JOIN and RIGHT JOIN in SQL
LEFT JOIN and RIGHT JOIN are types of SQL OUTER JOINs. They are used to fetch data from two tables based on a matching condition, while also including unmatched rows from one of the tables.
1. LEFT JOIN
- The
LEFT JOINreturns all rows from the left table, and the matched rows from the right table. - If there is no match, the result contains
NULLfor the columns of the right table.
Syntax:
SELECT columns
FROM table1
LEFT JOIN table2
ON table1.column = table2.column;
Example:
Table: Employees
| EmployeeID | Name | DepartmentID |
|---|---|---|
| 1 | Alice | 101 |
| 2 | Bob | 102 |
| 3 | Charlie | NULL |
| 4 | Diana | 104 |
Table: Departments
| DepartmentID | DepartmentName |
|---|---|
| 101 | HR |
| 102 | IT |
| 103 | Finance |
Query:
SELECT Employees.Name, Departments.DepartmentName
FROM Employees
LEFT JOIN Departments
ON Employees.DepartmentID = Departments.DepartmentID;
Result:
| Name | DepartmentName |
|---|---|
| Alice | HR |
| Bob | IT |
| Charlie | NULL |
| Diana | NULL |
- All rows from
Employeesare included. - Rows without a match in
Departments(likeCharlieandDiana) showNULL.
2. RIGHT JOIN
- The
RIGHT JOINreturns all rows from the right table, and the matched rows from the left table. - If there is no match, the result contains
NULLfor the columns of the left table.
Syntax:
SELECT columns
FROM table1
RIGHT JOIN table2
ON table1.column = table2.column;
Example:
Using the same tables Employees and Departments.
Query:
SELECT Employees.Name, Departments.DepartmentName
FROM Employees
RIGHT JOIN Departments
ON Employees.DepartmentID = Departments.DepartmentID;
Result:
| Name | DepartmentName |
|---|---|
| Alice | HR |
| Bob | IT |
| NULL | Finance |
- All rows from
Departmentsare included. - Rows without a match in
Employees(likeFinance) showNULL.
Key Differences
| Feature | LEFT JOIN | RIGHT JOIN |
|---|---|---|
| Included Rows | All rows from the left table. | All rows from the right table. |
| Unmatched Rows |
NULL for unmatched right table. |
NULL for unmatched left table. |
| Primary Use | Ensure all rows from the left table appear. | Ensure all rows from the right table appear. |
When to Use?
-
LEFT JOIN: Use when you want all data from the left table, regardless of matches in the right table. -
RIGHT JOIN: Use when you want all data from the right table, regardless of matches in the left table.
By presenting tables neatly and explaining key concepts with examples, the structure remains easy to understand and visually appealing.
Hi, I'm Abhay Singh Kathayat!
I am a full-stack developer with expertise in both front-end and back-end technologies. I work with a variety of programming languages and frameworks to build efficient, scalable, and user-friendly applications.
Feel free to reach out to me at my business email: kaashshorts28@gmail.com.
Top comments (0)