问小白 wenxiaobai
资讯
历史
科技
环境与自然
成长
游戏
财经
文学与艺术
美食
健康
家居
文化
情感
汽车
三农
军事
旅行
运动
教育
生活
星座命理

图解数据库左连接、右连接、内连接、外连接、全连接的区别

创作时间:
作者:
@小白创作中心

图解数据库左连接、右连接、内连接、外连接、全连接的区别

引用
CSDN
1.
https://blog.csdn.net/qq_27184497/article/details/119672665

在数据库查询中,连接(Join)是一种常用的操作,用于从多个表中获取数据。不同的连接方式(如内连接、外连接、左连接、右连接和全连接)会根据特定的条件返回不同的结果集。本文将通过具体的SQL语句和示例数据表,详细解释这些连接方式的区别。

数据库连表方式

  • 内连接:

  • 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,可以通过UNION实现全连接:

SELECT * FROM A LEFT JOIN B ON A.id = B.id
UNION
SELECT * FROM A RIGHT JOIN B ON A.id = B.id;
© 2023 北京元石科技有限公司 ◎ 京公网安备 11010802042949号