How to write different types of joins in SQL?
SQL JOIN
A JOIN clause is used to combine rows from two or more tables, based on a related column between them.
Different Types of SQL JOINs
- (INNER) JOIN: Returns records that have matching values in both tables
- LEFT (OUTER) JOIN: Returns all records from the left table, and the matched records from the right table
- RIGHT (OUTER) JOIN: Returns all records from the right table, and the matched records from the left table
- FULL (OUTER) JOIN: Returns all records when there is a match in either left or right table
- SELF JOIN: A self join is a regular join, but the table is joined with itself.
data:image/s3,"s3://crabby-images/ad2b3/ad2b3a10b5a059f5cbd5f743442dd0dba3b8feea" alt=""
I am using two tables: “users” and “address” in this context.
data:image/s3,"s3://crabby-images/51855/518557a493b572e132efc7a264f86ba1e0d48df7" alt=""
INNER JOIN
SELECT u.user_id, u.user_name, u.user_phone, a.city, a.pin
FROM users AS u
INNER JOIN address AS a ON a.user_id_fk = u.user_id
data:image/s3,"s3://crabby-images/40139/40139239289f2adf3bb78c452817b5c81989a132" alt=""
LEFT (OUTER) JOIN
LEFT OUTER JOIN and LEFT JOIN are the same.
SELECT u.user_id, u.user_name, u.user_phone, a.city, a.pin
FROM users AS u
LEFT JOIN address AS a ON a.user_id_fk = u.user_id
data:image/s3,"s3://crabby-images/31fc8/31fc8b70f1a9e1b3d958ce5d13a6a9f7a591dea0" alt=""
RIGHT (OUTER) JOIN
RIGHT OUTER JOIN and RIGHT JOIN are the same.
SELECT u.user_id, u.user_name, u.user_phone, a.city, a.pin
FROM users AS u
RIGHT JOIN address AS a ON a.user_id_fk = u.user_id
data:image/s3,"s3://crabby-images/9e8a3/9e8a3f335f86c2e46826dbae522f43dfe8626c82" alt=""
FULL (OUTER) JOIN
FULL OUTER JOIN and FULL JOIN are the same.
SELECT u.user_id, u.user_name, u.user_phone, a.city, a.pin
FROM users AS u
FULL JOIN address AS a ON a.user_id_fk = u.user_id
data:image/s3,"s3://crabby-images/fd573/fd5733839c76a45531a7ee1d40a622d410b8bb0f" alt=""
SELF JOIN
SELECT a1.city, a1.pin as pin1, a2.pin AS pin2
FROM address AS a1, address AS a2
WHERE a1.pin <> a2.pin
AND a1.city = a2.city
data:image/s3,"s3://crabby-images/10191/10191d58796d5ed712134fee2deb7bb3989d1efc" alt=""