left join、right join和join,傻傻分不清?



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


真的是一张图道清全部join的区别啊,惋惜我仍是看不懂,可能人比较懒,而后基本一个left join给我就是够用的了,因此就没怎么去仔细研究了,可是现实仍是逼我去搞清楚,索性本身动手,总算理解图中的含义了,下面就听我一一道来。微信

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

clipboard.pngclipboard.png

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

select
   *
from
   kemu
left join score on kemu.id = score.id复制代码

结果集:
clipboard.pngclipboard.pngcode

2、right joincdn

“右链接”,表1右链接表2,以右为主,表示以表2为主,关联查询表1的数据,查出表2全部数据以及表1和表2有交集的数据,以下:blog

select
   *
from
   kemu
right join score on kemu.id = score.id复制代码

结果集:ip

clipboard.pngclipboard.png

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

select
   *
from
   kemu
join score on kemu.id = score.id复制代码

结果集:it

clipboard.pngclipboard.png

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

BLOG地址:www.liangsonghua.com

关注微信公众号:松花皮蛋的黑板报,获取更多精彩!

公众号介绍:分享在京东工做的技术感悟,还有JAVA技术和业内最佳实践,大部分都是务实的、能看懂的、可复现的

相关文章
相关标签/搜索