图解数据库左连接、右连接、内连接、外连接、全连接的区别
创作时间:
作者:
@小白创作中心
图解数据库左连接、右连接、内连接、外连接、全连接的区别
引用
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;
热门推荐
纳米二氧化硅制备方法的研究与应用
提高解决问题能力的6种有效方法
抑郁症和焦虑症有何区别?会同时发生吗?
秋冬咳嗽?试试这款玉竹百合汤!
人生的意义与目的
望夷宫之变:秦朝权力更迭的转折点
造口回纳手术黄金时机,你知道吗?
造口回纳手术黄金时机,你知道吗?
睡眠不好可能诱发脂肪肝?最新研究结果,还会伤肾
“梦境预示健康隐患,警惕这些警示信号”
清东陵万佛园:古典园林艺术的现代演绎
清东陵探秘:帝王陵墓里的那些事儿
纯惠皇贵妃:一位苏州美女的宫廷传奇
揭秘清东陵:皇家陵寝的神秘设计
世界文化遗产清东陵:五位皇帝的安息之所
解读梦见被狗咬:注意梦境的具体内容
造口饮食健康宣教
如何做好肠道“造口”日常护理?
胡亥与子婴:秦朝晚期的叔侄关系探究
中国三百五十帝:秦二世嬴胡亥 极具争议性君主 统治时期短暂而残暴
秦始皇所创制度的影响是什么
秦王子婴:秦朝末代皇帝,在位仅46天的秦三世
1999年属兔人春节社交攻略:如何在聚会中找到另一半
遗嘱见证人的具体条件:法律明确规定与实际操作
赵本山:东北喜剧之魂的传奇人生
赵本山新片遭遇口碑滑铁卢,与《你好,李焕英》差距何在?
经济犯罪侦查与大数据:利用科技手段提高侦查效率
大数据分析:打击违法犯罪的新利器
大数据在教育中的应用:幼儿园营养配餐管理系统的实践
基因编辑技术之“合”力量:破解权衡效应的育种瓶颈