1. SQL JOIN
简单介绍
SQL JOIN 子句是基于表之间的共同字段,把来自多个表的行连接就是结合起来。
分类
INNER JOIN: 如果表中有至少一个匹配,则返回行。
LEFT JOIN: 即使右表中没有匹配,也从左表中返回所有的行。
RIGHT JOIN: 即使左表中没有匹配,也从右表中返回所有的行。
FULL JOIN: 只要有一个表中存在匹配,就返回行。
2. INNER JOIN
数据库
用下面的数据库进行讲解:
两个表table_1, table_2。
如下:table_1:
id | Name |
---|---|
1 | |
2 | 淘宝 |
3 | 微博 |
4 |
table_2:
id | Address |
---|---|
1 | 美国 |
3 | 中国 |
5 | 中国 |
6 | 美国 |
语法
SELECT column_name(s)
FROM table1
INNER JOIN table2
ON table1.column_name=table2.column_name;
或者
SELECT column_name(s)
FROM table1
JOIN table2
ON table1.column_name=table2.column_name;
图示
从这个图中咱们可以看到INNER JOIN拿出的数据是两个表相交的数据。
语句实例
select * from table_1
inner join table_2
on table_1.id=table_2.id
执行上述语句输出的结果如下:
id | Name | Address |
---|---|---|
1 | 美国 | |
3 | 微博 | 中国 |
3. LEFT JOIN
LEFT JOIN 关键字从左表(table_1)返回所有的行,即使右表(table_2)中没有匹配。如果右表中没有匹配,则结果为 NULL。
语法
SELECT column_name(s)
FROM table1
LEFT JOIN table2
ON table1.column_name=table2.column_name;
图示
语句实例
select * from table_1
left join table_2
on table_1.id=table_2.id
执行上述语句输出的结果如下:
id | Name | Address |
---|---|---|
1 | 美国 | |
2 | 淘宝 | null |
3 | 微博 | 中国 |
4 | null |
4. RIGHT JOIN
RIGHT JOIN 关键字会从右表(table_2)返回所有的行,即使左表(table_1)中没有匹配。如果左表中没有匹配,则结果为 NULL。
语法
SELECT column_name(s)
FROM table_1
RIGHT JOIN table_2
ON table_1.column_name=table_2.column_name;
图示
语句实例
select * from table_1
right join table_2
on table_1.id=table_2.id
执行上述语句输出的结果如下:
id | Name | Address |
---|---|---|
1 | 美国 | |
3 | 微博 | 中国 |
5 | null | 中国 |
6 | null | 美国 |
5. FULL JOIN
FULL JOIN 会从左表 和右表 那里返回所有的行。如果其中一个表的数据行在另一个表中没有匹配的行,那么对面的数据用NULL代替。
语法
select column_name(s)
from table 1
FULL OUTER JOIN table 2
ON table 1.column_name=table 2.column_name
图示
语句实例
select * from table_1
full outer join table_2
on table_1.id=table_2.id
执行以上SQL输出结果如下:
id | name | address |
---|---|---|
1 | 美国 | |
2 | 淘宝 | null |
3 | 微博 | 中国 |
4 | null | |
5 | null | 中国 |
6 | null | 美国 |
图来自菜鸟教程。