抱歉,您的浏览器无法访问本站

本页面需要浏览器支持(启用)JavaScript


了解详情 >

clipboard.png

真的是一张图道清所有join的区别啊,可惜我还是看不懂,可能人比较懒,然后基本一个left join给我就是够用的了,所以就没怎么去仔细研究了,但是现实还是逼我去搞清楚,索性自己动手,总算理解图中的含义了,下面就听我一一道来。

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

clipboard.pngclipboard.png

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

1
2
3
4
5
select
*
from
kemu
left join score on kemu.id = score.id

结果集:
clipboard.pngclipboard.png

二、right join

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

1
2
3
4
5
select
*
from
kemu
right join score on kemu.id = score.id

结果集:

clipboard.pngclipboard.png

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

1
2
3
4
5
select
*
from
kemu
join score on kemu.id = score.id

结果集:

clipboard.pngclipboard.png

评论