当前位置:   article > 正文

mysql三种join的介绍区别_mysql inner join和join的区别

mysql inner join和join的区别

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

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

71326b7e42d2707f30c204232125d224.png 

 

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

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

select
   *
from
   kemu
left join score on kemu.id = score.id
结果集:

9a1e2eca3c1782e983becdc827d6fd22.png

 

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

select
   *
from
   kemu
right join score on kemu.id = score.id
结果集:

ad82de5975981c74ee6b43b3ac6416b5.png

 

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

select
   *
from
   kemu
join score on kemu.id = score.id
结果集:

7700b8a4fe6bae946139e939d0dfcb20.png

inner join不会产出空字段、 left join、 right join会产生空字段

inner join 左表的值逐个和右表进行匹配(匹配条件来自哪?on后的语句),一旦匹配上了,生成一条数据。如果右表有多行数据与左表匹配,则生成多条数据

inner join不会产生空字段的行

left join 左表的数据全部列出,右表的数据逐一进行匹配,匹配上生成一条数据。如果右表有多行数据与左表匹配,则生成多条数据

会产生空字段的行

right join 右表的数据全部列出,左表的数据逐一进行匹配,匹配上生成一条数据。如果左表有多行数据与右表匹配,则生成多条数据

会产生空字段的行

他们的共同特点都是笛卡尔积的过程,会产生冗余数据

 

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号