图解数据库左连接、右连接、内连接、外连接、全连接的区别
创作时间:
作者:
@小白创作中心
图解数据库左连接、右连接、内连接、外连接、全连接的区别
引用
CSDN
1.
https://blog.csdn.net/qq_27184497/article/details/119672665
在数据库查询中,连接(Join)是一种常用的操作,用于从多个表中获取数据。不同的连接方式(如内连接、外连接、左连接、右连接和全连接)会根据特定的条件返回不同的结果集。本文将通过具体的SQL语句和示例数据表,详细解释这些连接方式的区别。
数据库连表方式
内连接:
INNERINNER JOIN外连接:
OUTER JOIN左外连接:
LEFT OUTER JOIN左连接:
LEFT JOIN右外连接:
RIGHT OUTER JOIN右连接:
RIGHT JOIN全连接:
FULL JOINUNION
准备
现在有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,可以通过UNION实现全连接:
SELECT * FROM A LEFT JOIN B ON A.id = B.id
UNION
SELECT * FROM A RIGHT JOIN B ON A.id = B.id;
热门推荐
5种中国传统健身操让您神清气爽迎接春天
提高精气神的中医方法
英国女王怎么选
石灰厂生产设备选型考量因素有哪些
“川剧变脸”津门竞技 师生联袂传承技艺
日语翻译成中文的五个实用技巧
用好民族文化资源 激发文旅融合新活力
特征选择算法详解
XGBoost简单推导及理解
运动强度如何量化?心率区间训练详解
连翘种植全攻略:从种植时间到养护技巧一文详解
连翘花的寓意和象征(探索连翘花的美与哲学)
《自然》子刊:怀孕对大脑的影响,实在是太大了
孕期需不需要经常进行产前检查?
红海市场与蓝海市场的区别
汉中之战失利后 张鲁选择投降曹操 为何不投靠刘备?
CPD是什么项目管理
段永平:保持好奇心,持续学习
探究帝王尊号:太祖与高祖的区别及称谓由来
青山埋忠骨|这是“八宝山第一墓”
学校人事管理系统与普通系统有什么区别?
LOF基金的投资策略有哪些?这些策略的实施难点是什么?
做试管婴儿有没有必要请假3个月?
网上祭祀,让思念跨越时空,与故人共享安宁与温馨
工伤后怎么跟公司谈赔偿金
大医精诚(原文及译文、注释)
2025年中国海军展望:多达19万吨舰等待服役,整体规模再创新纪录
不同网络如何设置文件夹共享:一网打尽共享文件夹设置技巧
活性炭使用指南:如何判断活性炭是否需要更换
下一代恐怖游戏会是什么样的