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:

idName
1Google
2淘宝
3微博
4Facebook

table_2:

idAddress
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

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

idNameAddress
1Google美国
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

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

idNameAddress
1Google美国
2淘宝null
3微博中国
4Facebooknull

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

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

idNameAddress
1Google美国
3微博中国
5null中国
6null美国

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输出结果如下:

idnameaddress
1Google美国
2淘宝null
3微博中国
4Facebooknull
5null中国
6null美国

图来自菜鸟教程。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值