SQL中INNER JOIN, LEFT JOIN, RIGHT JOIN, FULL JOIN的使用

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 Google
2 淘宝
3 微博
4 Facebook

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;

图示

SQL INNER JOIN

从这个图中咱们可以看到INNER JOIN拿出的数据是两个表相交的数据。

语句实例

select * from table_1 
inner join table_2
on table_1.id=table_2.id

执行上述语句输出的结果如下:

id Name Address
1 Google 美国
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;

图示

SQL LEFT JOIN

语句实例

select * from table_1 
left join table_2
on table_1.id=table_2.id

执行上述语句输出的结果如下:

id Name Address
1 Google 美国
2 淘宝 null
3 微博 中国
4 Facebook 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;

图示

img

语句实例

select * from table_1 
right join table_2
on table_1.id=table_2.id

执行上述语句输出的结果如下:

id Name Address
1 Google 美国
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

图示

img

语句实例

select * from table_1 
full outer join table_2
on table_1.id=table_2.id

执行以上SQL输出结果如下:

id name address
1 Google 美国
2 淘宝 null
3 微博 中国
4 Facebook null
5 null 中国
6 null 美国

图来自菜鸟教程。

猜你喜欢

转载自blog.csdn.net/hello_cmy/article/details/108072242