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

连接查询join经常使用,但是一直没有完全搞明白各种用法的区别,left join、right join、join和inner join等等各种join,到底有什么区别? 官网给出的总结性质的图:

【mySQL】left join、right join和join的区别_第1张图片

这张图总结了所有join的区别,如果只是看的话,那么还是看不懂,必须自己动手试试。

建立两张表来进行连接查询,第一张表命名为kemu,第二张表命名为score:

【mySQL】left join、right join和join的区别_第2张图片

1. left join

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

select  *

from kemu

left join score

on kemu.id = score.id

结果:

【mySQL】left join、right join和join的区别_第3张图片 

 

2. right join

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

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

结果: 

【mySQL】left join、right join和join的区别_第4张图片 

 

3. join

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

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

结果: 

【mySQL】left join、right join和join的区别_第5张图片 

 

你可能感兴趣的:(数据库,mysql,数据库,database)