sql中左连接和左外连接的区别是什么-SQL

admin1年前 (2024-06-05)基础运维知识268
点击下载TXT

左连接与左外连接的区别

左连接和左外连接是两个在 SQL 中常用的连接操作,用于从不同表中获取数据。主要区别在于左连接会返回所有来自左表(或驱动表)的行,而左外连接会返回所有来自左表的行,以及来自右表(或从属表)的匹配行或 NULL 值。

左连接 (INNER JOIN)

  • 返回来自左表和右表的匹配行。
  • 只有当右表中有匹配的记录时,才会返回左表中的行。
  • 如果右表中没有匹配的记录,则左表中的行将被排除在外。

左外连接 (LEFT JOIN)

  • 返回来自左表的所有行。
  • 对于在右表中找到匹配的左表行,返回匹配的右表列值。
  • 对于在右表中没有匹配的左表行,返回 NULL 值。

示例

使用以下表进行说明:

表 A

ID 名称
1 John
2 Mary
3 Bob

表 B

ID 部门
1 销售
2 营销

左连接查询:

SELECT *
FROM A
INNER JOIN B
ON A.ID = B.ID;
登录后复制

结果:

ID 名称 部门
1 John 销售
2 Mary 营销

左外连接查询:

SELECT *
FROM A
LEFT JOIN B
ON A.ID = B.ID;
登录后复制

结果:

ID 名称 部门
1 John 销售
2 Mary 营销
3 Bob NULL

如您所见,左外连接返回了表 A 中的所有行,即使在表 B 中没有匹配的记录,也会返回 NULL 值。

相关文章

oracle物化视图怎么设置-Oracle

Oracle 物化视图设置指南 什么是物化视图? 物化视图是存储在数据库中对基础表的预计算结果的只读副本。它可以提高需要频繁访问相同数据集的查询的性能。 如何设置物化视图? 步骤 1:创建基础表 创...

mysql自增id怎么办-mysql教程

MySQL 的自增 ID 机制 MySQL 数据库使用自增 ID 机制为新插入的行自动生成唯一的 ID 值。这个 ID 值通常是一个递增的整数,例如 1、2、3 等。自增 ID 机制在许多情况下都非...

mysql怎么导入mdf文件-mysql教程

如何将 MDF 文件导入 MySQL MySQL 无法直接导入 Microsoft SQL Server (MSSQL) 的 MDF 文件。但是,可以通过以下步骤将 MDF 文件中的数据迁移到 My...

mysql分组排序怎么查-mysql教程

MySQL 分组排序查询方法 在 MySQL 中,可以通过使用 GROUP BY 和 ORDER BY 子句对结果集进行分组和排序。 分组 GROUP BY 子句将行按指定的列或表达式分组,并将每个...

mongodb备份怎么导入-MongoDB

MongoDB 备份导入指南 如何导入 MongoDB 备份? 要导入 MongoDB 备份,请遵循以下步骤: 第 1 步:停止 MongoDB 进程 在尝试还原之前,请确保已停止 MongoDB...

mysql分库分表怎么实现-mysql教程

MySQL 分库分表实现 MySQL 分库分表是将一个巨型数据库拆分为多个较小的数据库或表,以解决单库容量瓶颈和性能问题。 实现步骤 确定分库分表规则:根据数据特征确定分库分表维度,如用户 ID...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。