说到SQL,很多人可能用了挺久,但依然有个问题一直困扰着,那就是 left join、 join、 right join和 inner join等等各种 join的区别。网上搜,最常见的就是一张图解图,如下:
![8e60f260a35c86fa452bcaf39ad9e7a3.png](https://i-blog.csdnimg.cn/blog_migrate/cb4296ec0c53476e0304d781a2051b40.jpeg)
接下来就来实际自己动手实验,彻底搞懂图中的含义。
首先,先来建两张表,第一张表命名为 kemu,第二张表命名为 score:
![5af3dff27049628e4567e8ec43d0e7c8.png](https://i-blog.csdnimg.cn/blog_migrate/ee0cd701b311f9ec5b40fe275a3ff441.jpeg)
![4754ff86893a18265b2a25f6152fc05b.png](https://i-blog.csdnimg.cn/blog_migrate/4c81e5b1c19e5fb62dce5a212f7bcc3b.jpeg)
left join
顾名思义,就是“左连接”,表1左连接表2,以左为主,表示以表1为主,关联上表2的数据,查出来的结果显示左边的所有数据,然后右边显示的是和左边有交集部分的数据。如下:
select *from kemuleft join score on kemu.id = score.id
结果集:
![38282ca1d82a99dc58e18de1422277e6.png](https://i-blog.csdnimg.cn/blog_migrate/e7d2ef0cb1b3491d9675580326a62961.jpeg)
![fdbda57d402e3bd7f46694f8be959467.png](https://i-blog.csdnimg.cn/blog_migrate/396b66836b06d1b0aef373693eba4ff8.jpeg)
right join
“右连接”,表1右连接表2,以右为主,表示以表2为主,关联查询表1的数据,查出表2所有数据以及表1和表2有交集的数据,如下:
select *from kemuright join score on kemu.id = score.id
结果集:
![262b408635ed709e23b0467dd1c8cad0.png](https://i-blog.csdnimg.cn/blog_migrate/5f45bf6e9767ccf40e4492be55c424c3.jpeg)
![db1310280993c850e3dbd60f18d847d3.png](https://i-blog.csdnimg.cn/blog_migrate/fd2cdc1ddc5e9d327097e4f3fce8853a.jpeg)
join(inner join)
join,其实就是“inner join”,为了简写才写成join,两个是表示一个的,内连接,表示以两个表的交集为主,查出来是两个表有交集的部分,其余没有关联就不额外显示出来,这个用的情况也是挺多的,如下
select *from kemujoin score on kemu.id = score.id
结果集:
![0d7070a97958de22d593a57d2acc24d3.png](https://i-blog.csdnimg.cn/blog_migrate/097456aa7cc001d25510b5860e59bf37.jpeg)
![822144efd7626feed508e01c4f8a20b3.png](https://i-blog.csdnimg.cn/blog_migrate/e2f0eb998faa4905cd78a8d32fcf8572.jpeg)
以后对于这三者应该再也不模糊了吧!