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

admin2年前 (2024-06-05)基础运维知识252
点击下载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

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

相关文章

mysql 42000到底怎么解决-mysql教程

如何解决 MySQL 错误 42000 MySQL 错误 42000 通常是由锁等待造成的。当一个线程尝试获取另一个线程已持有的锁时,就会发生这种情况。 解决方法: 1. 确定导致锁等待的查询 使...

mongodb客户端怎么启动-MongoDB

如何启动 MongoDB 客户端 步骤 1:安装 MongoDB 访问 MongoDB 网站:https://www.mongodb.com/download-center/community 选...

oracle物化视图怎么设置-Oracle

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

mysql是什么有什么用-mysql教程

什么是 MySQL? MySQL 是一个开源关系数据库管理系统(RDBMS),用于存储和管理数据。它是一种广泛用于 Web 应用程序、电子商务和数据仓储等各种领域的流行数据库。 MySQL 的用途...

sql游标实例怎么用-SQL

SQL 游标简介 SQL 游标是一种允许程序逐行访问结果集的机制。它类似于指针,指向结果集中的当前行。 实例 创建游标 DECLARE cursor_name CURSOR FOR SELECT *...

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

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

发表评论

访客

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