搞明白 left join、right join和join的区别

left join、join、right join和inner join等等各种join的区别。网上搜,最常见的就是一张图解图,如下:
搞明白 left join、right join和join的区别_第1张图片
一、left join
left是左边的意思,join是连接的意思,连起来就是“左连接”,表1左连接表2,以左为主,表示以表1为主,关联上表2的数据,查出来的结果显示左边的所有数据,然后右边显示的是和左边有交集部分的数据。如下:

select  * from subject
left join score on subject.id = score.id

搞明白 left join、right join和join的区别_第2张图片
二、right join
right是右边的意思,join是连接的意思,加起来就是“右连接”,表1右连接表2,以右为主,表示以表2为主,关联查询表1的数据,查出表2所有数据以及表1和表2有交集的数据,如下:

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

搞明白 left join、right join和join的区别_第3张图片
三、join
join,其实就是“inner join”,为了简写才写成join,两个是表示一个的,内连接,表示以两个表的交集为主,查出来是两个表有交集的部分,其余没有关联就不额外显示出来,这个用的情况也是挺多的,如下:

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


搞明白 left join、right join和join的区别_第4张图片

Join 等同于 inner join : 表示两个表都必须存在的
left join 表示以左边的表为基准,不管你右边的表有没有都显示
right join和left join刚好相反
full outer join表示只要在两个表中任何一个表中有的都显示

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