【mySQL】left join、right join和join的区别

25次阅读

共计 706 个字符,预计需要花费 2 分钟才能阅读完成。

哈,好久没更新文章了,今天来说说关于 mySQL 那些年的小事。说到 mySQL 啊,用了挺久的了,但是有个问题一直在困扰着我,就是 left join、join、right join 和 inner join 等等各种 join 的区别。网上搜,最常见的就是一张图解图,如下:

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

一、left join 顾名思义,就是“左连接”,表 1 左连接表 2,以左为主,表示以表 1 为主,关联上表 2 的数据,查出来的结果显示左边的所有数据,然后右边显示的是和左边有交集部分的数据。如下:
select
*
from
kemu
left join score on kemu.id = score.id
结果集:
二、right join
“右连接”,表 1 右连接表 2,以右为主,表示以表 2 为主,关联查询表 1 的数据,查出表 2 所有数据以及表 1 和表 2 有交集的数据,如下:
select
*
from
kemu
right join score on kemu.id = score.id
结果集:

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

以上就是三种连接的区别!

正文完
 0