图解数据库左连接、右连接、内连接、外连接、全连接的区别
创作时间:
作者:
@小白创作中心
图解数据库左连接、右连接、内连接、外连接、全连接的区别
引用
1
来源
1.
https://www.coonote.com/mysql-note/left-right-outer-join.html
数据库连表方式
内连接:
inner
inner join
外连接:
outer join
左外连接:
left outer join
左连接:
left join
右外连接:
right outer join
右连接:
right join
全连接:
full join
union
准备
现在有2张表,A表和B表,数据和表结构如下:
内连接
内连接查询的是两张表的并集,也就是A表和B表都必须有数据才能查询出来;
以下三个查询的结果是一样的,针对上面的表数据,能查询出id为1、2、3的数据:
-- join
select * from A join B on A.id = B.id
-- inner join
select * from A inner join B on A.id = B.id
-- 逗号的连表方式就是内连接
select * from A , B where A.id = B.id
左外连接 和 左连接
是以左表为基础,根据ON后给出的两表的条件将两表连接起来。结果会将左表所有的查询信息列出,而右表只列出ON后条件与左表满足的部分。左连接全称为左外连接,是外连接的一种。
下面2个查询的结果是一样的,针对上面的表数据,能查询出id为1、2、3、4的数据:
-- left join
select * from A left join B on A.id = B.id
-- left outer join
select * from A left outer join B on A.id = B.id
右外连接 和 右连接
是以右表为基础,根据ON后给出的两表的条件将两表连接起来。结果会将右表所有的查询信息列出,而左表只列出ON后条件与右表满足的部分。右连接全称为右外连接,是外连接的一种。
下面2个查询的结果是一样的,针对上面的表数据,能查询出id为1、2、3的数据:
-- right join
select * from A right join B on A.id = B.id
-- right outer join
select * from A right outer join B on A.id = B.id
全连接
全连接显示两侧表中所有满足检索条件的行。
Oracle的全连接
Oracle的全连接查询可以直接用full join:
select * from a full join b on a.id = b.id
MySQL的全连接
MySQL中没有full join,MySQL可以使用union实现全连接:
select * from a left join b on a.id = b.id
union
select * from a right join b on a.id = b.id
热门推荐
危化品运输注意事项及自救指南
生活小妙招:教你轻松清洁枕头,让其恢复如新
如何有效利用IB课程英语自学网站提升英语能力
《水调歌头·游泳》赏析与朗诵指南
如何分析具有 10 倍潜力的小盘股
什么是二元性?二元性在不同领域有哪些体现?
春游惠州怎么玩?这份深度攻略请收好!
中度脂肪肝该怎么调理?
拓渠道、延链条、提质效,持续推动林果产业高质量发展
被狗咬伤,只打疫苗可不够,伤口还需这样处理!
处方外流获政策支持,9省建立流转平台,4千亿院外市场将落地!
从脚本到成片:揭秘高端宣传片制作的7个核心流程
遗嘱能把财产留给别人吗
傅里叶级数详解:从理论到实践
极简主义大师原研哉,少即多的设计智慧
如何用ASP编写Web后台
触摸屏硬件安装与连接指南(含部分失灵修复小技巧)
手机空号的成因、处理方法及注意事项详解
如何增强儿童的远视储备
层高太矮很压抑?装修时利用这六种手段,让房间显得更高挑!
uniapp前端如何解决跨域
血液EGFR突变检测技术或将改变肿瘤治疗临床路径
新形势下餐饮的发展与布局:创新引领,策略先行
最常见的十大绿篱植物
广州经济向上突围,关键“一”招何在?
摸排单身汉,政府请红娘:大理州出招解农村婚配难题
七类网线详解:如何快速制作七类网线水晶头?
抽象行政行为和具体行政行为的区别和联系
如何收集和保存交通事故证据以提起诉讼
误食口香糖怎么办