图解数据库左连接、右连接、内连接、外连接、全连接的区别
创作时间:
作者:
@小白创作中心
图解数据库左连接、右连接、内连接、外连接、全连接的区别
引用
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
热门推荐
“出发!北京的‘吴哥窟’,人少速去”
红旗H5油耗偏高?试试这些节油小技巧
警校公安联考一般人考得过吗?附可以参加公安联考的专业名单
退潮了?德云社相声大会商演打折加特惠,听云轩功不可没
高血压性视网膜病变的分期标准是什么
温医大眼视光医院团队揭示AIM2-AKT通路在PVR发病机制中的关键作用
“春天五不吃,远离寒和湿”,哪5不吃?早春时节,饮食要懂忌口
合约杠杆倍数是什么意思?如何理解合约杠杆倍数?
签名的法律效力及其法律责任:从法律角度深度解析
公司辞退员工时需保留的证据
阳朔漓江沿线景区
军人离婚要部队领导批准吗
无甲醛玻璃棉在室内隔音中的应用
PET不干胶与PVC不干胶的优缺点,你了解多少?
顺产对胎儿和准妈有这8大好处!剖腹产绝对比不了!
皮肤红疹是什么原因引起的
瑜伽:腰椎间盘突出与坐骨神经痛的天然缓解剂
地震来临时,老师是否应该优先救学生?法律给出了答案
环境工程与环境科学的区别
癔症是什么?带你了解分离转换障碍
中国棉纺织行业面临五大挑战 每一条都与纺织业未来的发展息息相关
德克兰·赖斯:从西汉姆联到阿森纳的中场核心
揭秘非洲公象:草原上的“巨无霸”究竟有多恐怖?
新生代演员孙嘉璐:从荧幕到学术,塑造多面精彩人生
养蚕的方法和注意事项(养蚕的注意事项有哪些)
天山童姥与少林扫地僧:武侠战力的多维剖析
大股东免债并不意味着*ST中程“上岸”,投资者还需留意这些风险
肠内营养液有哪些
赡养人分摊该怎么选?一文详解赡养人权益分配
如何通过色彩、比例和配饰等元素的巧妙搭配,提升自己的形象