博客 SQL——左连接(Left join)、右连接(Right join)、内连接(Inner join)

SQL——左连接(Left join)、右连接(Right join)、内连接(Inner join)

   数栈君   发表于 2023-09-21 10:51  1804  0

前言

最近在做SQL相关的练习,发现以前那么自信的SQL放久了不碰也变得棘手起来,特别是这一块表之间的内外连接。所以这篇是关于这个内外连接的整理。

一、概念

首先还是介绍一下这三个的定义

1.Left join:即左连接,是以左表为基础,根据ON后给出的两表的条件将两表连接起来。结果会将左表所有的查询信息列出,而右表只列出ON后条件与左表满足的部分。左连接全称为左外连接,是外连接的一种。

2.Right join:即右连接,是以右表为基础,根据ON后给出的两表的条件将两表连接起来。结果会将右表所有的查询信息列出,而左表只列出ON后条件与右表满足的部分。右连接全称为右外连接,是外连接的一种。

3.Inner join:即内连接,同时将两表作为参考对象,根据ON后给出的两表的条件将两表连接起来。结果则是两表同时满足ON后的条件的部分才会列出。

MySQL中没有全外连接,所以这里没做解释了。

二、例子
表table_a

http://dtstack-static.oss-cn-hangzhou.aliyuncs.com/2021bbs/files_user1/article/fefd75796d8f22a9ed55dda5313fdaf0..jpg
  

表table_b

http://dtstack-static.oss-cn-hangzhou.aliyuncs.com/2021bbs/files_user1/article/719088261cd2515438aecc1a5c9ed25d..jpg
  

------------------------------------------------------分割线-----------------------------------------------------------------

Left join:左连接

SQL语句:

select *from table_a left join table_b on table_a.id=table_b.id;

结果:

http://dtstack-static.oss-cn-hangzhou.aliyuncs.com/2021bbs/files_user1/article/ac7482c97b885a9e0158d9aa0e939787..jpg
  

Right join:右连接

SQL语句:

select * from table_a right join table_b on table_a.id=table_b.id;

结果:
http://dtstack-static.oss-cn-hangzhou.aliyuncs.com/2021bbs/files_user1/article/876f96c2af6d448842ab683796880bdd..jpg
  

Inner join:内连接

SQL语句:

select * from table_a inner join table_b on table_a.id=table_b.id;

结果:
http://dtstack-static.oss-cn-hangzhou.aliyuncs.com/2021bbs/files_user1/article/1f7b443e988b5eea66329790890b5a44..jpg
  
总结
根据上面的栗子,看起来是不是清晰明了多了,而且也更有对比性了。如果还是觉得只是这会儿懂了,但是用起来还是觉得有点难的话,就下面这种集合思维,大头也是最近才发现,这样想的话就会简单很多了。

我们有两个表:A和B,那么就分别将其当做一个集合

那么我们的左右外连接和内连接就相当于变成了这样↓↓↓

A Left join B-> A (根据返回需求 需连接上B中与A等条件的部分)

A Right join B -> B(根据返回需求 需连接上A中与B等条件的部分)

A Inner join B -> A∩B(根据返回需求 需连接上A与B等条件的部分)
http://dtstack-static.oss-cn-hangzhou.aliyuncs.com/2021bbs/files_user1/article/b7cc5cd626fb309cc43c49958cd05c9e..jpg
  




免责申明:


本文系转载,版权归原作者所有,如若侵权请联系我们进行删除!

《数据治理行业实践白皮书》下载地址:https://fs80.cn/4w2atu

《数栈V6.0产品白皮书》下载地址:
https://fs80.cn/cw0iw1

想了解或咨询更多有关袋鼠云大数据产品、行业解决方案、客户案例的朋友,浏览袋鼠云官网:
https://www.dtstack.com/?src=bbs

同时,欢迎对大数据开源项目有兴趣的同学加入「袋鼠云开源框架钉钉技术群」,交流最新开源技术信息,群号码:30537511,项目地址:
https://github.com/DTStack


0条评论
社区公告
  • 大数据领域最专业的产品&技术交流社区,专注于探讨与分享大数据领域有趣又火热的信息,专业又专注的数据人园地

最新活动更多
微信扫码获取数字化转型资料
钉钉扫码加入技术交流群