图解数据库左连接、右连接、内连接、外连接、全连接的区别
创作时间:
作者:
@小白创作中心
图解数据库左连接、右连接、内连接、外连接、全连接的区别
引用
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;
热门推荐
石墨烯和石墨的区别和应用有哪些?这些区别和应用如何体现 ...
教资笔试时间:备考策略、流程及注意事项全攻略
神经内分泌失调的症状与护理
英语辅音和元音字母全解析
宠物蜘蛛怎么拍摄的?
蜘蛛痣的成因及注意事项
如何选择适合治疗眼部发炎的消炎药?
燃气报警器安装全攻略:为您的家增添一道安心防线
网贷逾期已还清还收到骚扰电话怎么办
喝酒后多久血液酒精浓度最高
长沙烟花鞭炮行业数字化转型首场供需对接会召开 34家企业达成合作意向
安全过冬:屋顶常见问题与维护
脱发问题:原因与有效对策讨论
同义词在语言表达中的作用与价值举例说明
广州周末亲子游好去处推荐
银行的信用卡账单日和还款日可以调整吗?
化妆品防伪码查询指南:位置、流程及注意事项全解析
如何实现顺畅的排气?排气系统的维护方法有哪些?
黑暗之魂3一级通关难点分析?如何克服挑战?
如何在写作中思考
华硕、技嘉、微星主板和显卡选购指南
现代家庭烧烤炉选购指南
职场社交中如何拓展人脉资源
探索太湖魅力:四条不容错过的自驾游线路推荐
潮州卤水的做法及配方大全
美国研究生申请高质量推荐信解析
沧州十大必游景点:从杂技大世界到湿地保护区
一级建筑师与注册规划师:哪个含金量更高?
2025重庆周边高铁3日游路线:成都
公司注销后还有什么风险