![43d9cb9dc4807c9c86f53344b60dbc7b.png](https://img-blog.csdnimg.cn/img_convert/43d9cb9dc4807c9c86f53344b60dbc7b.png)
文章来源: https:// urlify.cn/uIzIRr
原文作者:我是帅帅的玉米
来源平台:微信公众号
有个困扰
说到SQL,很多人可能用了挺久,但依然有个问题一直困扰着,那就是 left join
、join
、 right join
和 inner join
等等各种 join
的区别。网上搜,最常见的就是一张图解图,如下:
![97c92912d8986580d4dc9e2cfb3aaae0.png](https://img-blog.csdnimg.cn/img_convert/97c92912d8986580d4dc9e2cfb3aaae0.png)
接下来就来实际自己动手实验,彻底搞懂图中的含义。
首先,先来建两张表,第一张表命名为 kemu
,第二张表命名为 score
:
![9f5b82599247d2306f27c3476b095848.png](https://img-blog.csdnimg.cn/img_convert/9f5b82599247d2306f27c3476b095848.png)
![e1d8d8a86f046e13a26acb280df82569.png](https://img-blog.csdnimg.cn/img_convert/e1d8d8a86f046e13a26acb280df82569.png)
left join
顾名思义,就是“左连接”,表1左连接表2,以左为主,表示以表1为主,关联上表2的数据,查出来的结果显示左边的所有数据,然后右边显示的是和左边有交集部分的数据。如下:
select
*
from
kemu
left join score on kemu.id = score.id
结果集:
![1c59dba8866bcd524e06a14f0bc6780c.png](https://img-blog.csdnimg.cn/img_convert/1c59dba8866bcd524e06a14f0bc6780c.png)
![31ecff04b75231dd1a6b5dbd2a43c66b.png](https://img-blog.csdnimg.cn/img_convert/31ecff04b75231dd1a6b5dbd2a43c66b.png)
right join
“右连接”,表1右连接表2,以右为主,表示以表2为主,关联查询表1的数据,查出表2所有数据以及表1和表2有交集的数据,如下:
select
*
from
kemu
right join score on kemu.id = score.id
结果集:
![3b63eeeda329993b0d82c1b648578b78.png](https://img-blog.csdnimg.cn/img_convert/3b63eeeda329993b0d82c1b648578b78.png)
![ea9773654bcd2fecb6d26267dc7b65be.png](https://img-blog.csdnimg.cn/img_convert/ea9773654bcd2fecb6d26267dc7b65be.png)
join(inner join)
join,其实就是“inner join”,为了简写才写成join,两个是表示一个的,内连接,表示以两个表的交集为主,查出来是两个表有交集的部分,其余没有关联就不额外显示出来,这个用的情况也是挺多的,如下
select
*
from
kemu
join score on kemu.id = score.id
结果集:
![ee0874fa4f8ff18aeea44865710b15e9.png](https://img-blog.csdnimg.cn/img_convert/ee0874fa4f8ff18aeea44865710b15e9.png)
![72f90a470124a7d773288ebfb233b5dc.png](https://img-blog.csdnimg.cn/img_convert/72f90a470124a7d773288ebfb233b5dc.png)
以后对于这三者应该再也不模糊了吧!