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

点击上方“Java之间”,选择“置顶或者星标”

你关注的就是我关心的!

来源:segmentfault.com/a/1190000017369618

上一篇:世界10大编程语言,Java不是第一,PHP才第五


有个困扰

说到SQL,很多人可能用了挺久,但依然有个问题一直困扰着,那就是 left joinjoinright joininner join等等各种 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

结果集:


join(inner join)

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

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

结果集:

以后对于这三者应该再也不模糊了吧!

2019年12月16日

最近热文阅读:

1、世界10大编程语言,Java不是第一,PHP才第五

2、爱奇艺的数据库选型大法,实用不纠结!

3、面试官问:讲讲高并发下的接口幂等性怎么实现?

4、Tomcat 竟然有 bug,这我能信?

5、9个让你爱不释手的Json工具

6、拥有众多迷妹的Lombok了解一下

7、数据库查询速度优化之解决技巧

8、终于明白为什么要加 final 关键字了!

9、十大经典排序算法最强总结(内含代码实现),建议收藏!

10、ArrayList集合为什么不能使用foreach增删改

关注公众号,你想要的Java都在这里

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值