sql中左连接和内连接的区别-SQL

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

SQL 中左连接和内连接的区别

在 SQL 中,连接是将来自不同表的行组合在一起的强大工具。左连接和内连接是两种最常用的连接类型,它们在返回的结果方面有不同的行为。

左连接

左连接(LEFT JOIN)返回来自左表的所有行,即使右表中没有匹配的行。如果右表中没有匹配的行,则右表字段的值将显示为 NULL。

内连接

内连接(INNER JOIN)仅返回来自左表和右表中具有匹配行的行。如果没有匹配的行,则该行将不会被返回。

比较

特性 左连接 内连接
返回左表行 所有 仅匹配
处理右表空值 显示为 NULL 忽略
性能 较慢 较快
用例 获取左表所有数据,即使右表中没有匹配项 仅获取具有匹配行的行

示例

考虑以下两个表:

左表:
| id | 名称 |
|---|---|
| 1 | John |
| 2 | Mary |
| 3 | Bob |

右表:
| id | 地址 |
|---|---|
| 1 | 123 Main St |
| 2 | 456 Elm St |
登录后复制

左连接

SELECT *
FROM 左表
LEFT JOIN 右表
ON 左表.id = 右表.id;
登录后复制

结果:

id 名称 地址
1 John 123 Main St
2 Mary 456 Elm St
3 Bob NULL

内连接

SELECT *
FROM 左表
INNER JOIN 右表
ON 左表.id = 右表.id;
登录后复制

结果:

id 名称 地址
1 John 123 Main St
2 Mary 456 Elm St

正如您所看到的,左连接返回了左表的所有行,即使右表中没有匹配的行。而内连接只返回了两个表中都有匹配行的

相关文章

sql完整性约束怎么设置-SQL

SQL 完整性约束 什么是 SQL 完整性约束? SQL 完整性约束是一组规则,用于确保数据库中的数据准确性和一致性。它有助于防止不一致和无效的数据进入数据库。 如何设置 SQL 完整性约束? 在...

mysql怎么选择表-mysql教程

如何选择 MySQL 中的表 在 MySQL 数据库设计中,选择合适的表至关重要,因为它将影响数据库的性能和可维护性。以下是选择表的指南: 1. 确定表的目的和内容 首先,明确你要创建的表的用途。考...

mongodb怎么设置用户-MongoDB

如何设置 MongoDB 用户 MongoDB 是一个 NoSQL 数据库系统,它使用基于角色的访问控制 (RBAC) 来管理对数据的访问。要设置 MongoDB 用户,请按照以下步骤操作: 1....

mysql不能启动怎么办-mysql教程

MySQL无法启动:故障排除指南 原因和解决方案: 1. 进程已经启动 检查进程是否已经启动。运行以下命令: ps -ef |grep <a style="color:#f60;...

sql日期格式化怎么设置-SQL

SQL 日期格式化设置 如何设置 SQL 日期格式? 在 SQL 中,可以使用 TO_CHAR() 函数来格式化日期值。TO_CHAR() 函数第一个参数指定要转换的日期值,第二个参数指定格式化字符...

oracle怎么获取时间-Oracle

如何在 Oracle 中获取当前时间 在 Oracle 数据库中,获取当前时间可以使用 SYSDATE 系统变量。它返回服务器当前时间戳。 使用 SYSDATE 获取当前时间戳 SYSDATE 可以...

发表评论

访客

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