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

本文介绍了SQL中的左连接、右连接和内连接,通过概念解析和实例展示三者的区别。左连接以左表为主,显示所有左表记录及匹配的右表记录;右连接反之;内连接则只显示两表匹配的记录。理解这些概念有助于更好地进行SQL查询操作。
摘要由CSDN通过智能技术生成

文章目录


前言

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


一、概念

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

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

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

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

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

二、例子

表table_a

 表table_b

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


Left join:左连接

SQL语句:

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

结果:

 Right join:右连接

SQL语句:

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

结果:


Inner join:内连接

SQL语句:

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

 结果:


总结

根据上面的栗子,看起来是不是清晰明了多了,而且也更有对比性了。如果还是觉得只是这会儿懂了,但是用起来还是觉得有​点难的话,就下面这种集合思维,大头也是最近才发现,这样想的话就会简单很多了。

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

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

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

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

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

 

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值