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.
Every application that stores and manages data relies on a set of basic operations known…
PHP remains one of the most widely used server-side programming languages, powering platforms such as…
Danfo.js is an open-source JavaScript library designed for data manipulation, analysis, and machine learning. It provides…
JavaScript's async and await keywords revolutionized asynchronous programming by making asynchronous code look and behave more like synchronous code.…
Pretty Good Privacy (PGP) is one of the most widely used encryption systems for securing emails,…
Database migration is one of the most challenging tasks in software engineering. While both PostgreSQL…