In MySQL, joins are used to combine data from two or more tables based on a related column between them.
For example, imagine you have:
users tableorders tableYou can use a JOIN to connect each user to their orders.
Example Tables
users
| user_id | name |
|---|---|
| 1 | Ada |
| 2 | Ben |
| 3 | Chika |
orders
| order_id | user_id | item |
|---|---|---|
| 101 | 1 | Laptop |
| 102 | 1 | Keyboard |
| 103 | 2 | Mouse |
There are four main types of joins you’ll use:
Returns only the rows that have matching values in both tables.
Query:
SELECT users.name, orders.item
FROM users
INNER JOIN orders
ON users.user_id = orders.user_id;
Result:
| name | item |
|---|---|
| Ada | Laptop |
| Ada | Keyboard |
| Ben | Mouse |
Explanation:
Returns all rows from the left table, and matching rows from the right table.
If there’s no match, the result is NULL for columns from the right table.
Query:
SELECT users.name, orders.item
FROM users
LEFT JOIN orders
ON users.user_id = orders.user_id; Result:
| name | item |
|---|---|
| Ada | Laptop |
| Ada | Keyboard |
| Ben | Mouse |
| Chika | NULL |
Explanation:
3. RIGHT JOIN (or RIGHT OUTER JOIN)
Returns all rows from the right table, and matching rows from the left table.
If no match exists, you’ll get NULL from the left table.
Query:
SELECT users.name, orders.item
FROM users
RIGHT JOIN orders
ON users.user_id = orders.user_id; Result:
| name | item |
|---|---|
| Ada | Laptop |
| Ada | Keyboard |
| Ben | Mouse |
Explanation:
Returns all orders, even if the user table had missing data (though not in this example).
4. FULL JOIN (or FULL OUTER JOIN)
Returns all rows from both tables, with NULL where there’s no match.
Note: MySQL doesn’t support FULL OUTER JOIN directly,
but you can simulate it using a UNION of LEFT JOIN and RIGHT JOIN.
SELECT users.name, orders.item
FROM users
LEFT JOIN orders ON users.user_id = orders.user_id
UNION
SELECT users.name, orders.item
FROM users
RIGHT JOIN orders ON users.user_id = orders.user_id; 5. CROSS JOIN
Creates a Cartesian product — every row from the first table joins with every row from the second table.
Query:
SELECT users.name, orders.item
FROM users
CROSS JOIN orders; Result:
If there are 3 users and 3 orders, you’ll get 9 rows (3 × 3).
Use case: Rare — typically used for generating combinations or test data.
| Join Type | Returns | Example Use |
|---|---|---|
| INNER JOIN | Only matching rows | Users who made purchases |
| LEFT JOIN | All left table rows, plus matches | All users + their orders |
| RIGHT JOIN | All right table rows, plus matches | All orders + user details |
| FULL JOIN | All rows from both tables | Combine all users and all orders |
| CROSS JOIN | Every possible pair | Generate combinations |
Always use aliases for cleaner queries:
SELECT u.name, o.item
FROM users u
LEFT JOIN orders o
ON u.user_id = o.user_id; Use JOINs with indexes to improve performance.
Avoid unnecessary joins; each one adds computational cost.
Test with small datasets before scaling up.
Latest tech news and coding tips.
In JavaScript, it’s commonly used for: Recursive functions (like Fibonacci) Heavy calculations Repeated API/data processing…
For years, responsive design has depended almost entirely on media queries. We ask questions like: “If…
1. What is Task Scheduling? Task scheduling is the process of automatically running commands, scripts,…
Here’s a comprehensive, clear differentiation between a Website and a Web App, from purpose all the…
Visual Studio Code (VS Code) is powerful out of the box, but its real strength…
1. What Is a Variable in JavaScript? A variable is a named container used to store data…