当前位置:   article > 正文

join inner join的区别_left join、right join和join的区别

join、 inner join、 left join的区别

作者:我是帅帅的玉米

来源:https://segmentfault.com/a/1190000017369618

有个困扰

说到SQL,很多人可能用了挺久,但依然有个问题一直困扰着,那就是 left join、 join、 right join和 inner join等等各种 join的区别。网上搜,最常见的就是一张图解图,如下:

2d209016f5393ed9eb721890f166536d.png

接下来就来实际自己动手实验,彻底搞懂图中的含义。

首先,先来建两张表,第一张表命名为 kemu,第二张表命名为 score:

5082571b3b9af5cb6cb39fa964c81b6a.png
b2a5800a0181ae1a0ecd9cdcb2d21ac3.png

left join

顾名思义,就是“左连接”,表1左连接表2,以左为主,表示以表1为主,关联上表2的数据,查出来的结果显示左边的所有数据,然后右边显示的是和左边有交集部分的数据。如下:

select   *from   kemuleft join score on kemu.id = score.id

结果集:

d3556e901e9263a351250fbabcd3453e.png
6430ccd6f6dd6181dd121a4d7b0b103d.png

right join

“右连接”,表1右连接表2,以右为主,表示以表2为主,关联查询表1的数据,查出表2所有数据以及表1和表2有交集的数据,如下:

select   *from   kemuright join score on kemu.id = score.id

结果集:

7c0ea41367067d336685d5a953ebdf14.png
39195e07c06e0dace706da1870960ac2.png

join(inner join)

join,其实就是“inner join”,为了简写才写成join,两个是表示一个的,内连接,表示以两个表的交集为主,查出来是两个表有交集的部分,其余没有关联就不额外显示出来,这个用的情况也是挺多的,如下

select   *from   kemujoin score on kemu.id = score.id

结果集:

417e5b2df68d039071525cb9c3775c81.png
1c6e934236ff93bb625ac996ad9b70e3.png

以后对于这三者应该再也不模糊了吧!

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/木道寻08/article/detail/793063
推荐阅读
相关标签
  

闽ICP备14008679号