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

admin2年前 (2024-06-05)基础运维知识314
点击下载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怎么选择表-mysql教程

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

mysql授权怎么用-mysql教程

MySQL 授权指南 授权是什么? 授权是指授予其他用户访问和操作 MySQL 数据库的权限。 如何授权? 使用 MySQL 的 GRANT 语句可以授予授权。语法如下: GRANT ON TO...

mongodb客户端怎么启动-MongoDB

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

sql代码视图怎么打开-SQL

SQL 代码视图如何打开 打开 SQL 代码视图的步骤: 在 Azure Data Studio 中,连接到数据库服务器。 在“对象资源管理器”中,右键单击要查看代码的数据库对象(例如表、视图或存...

sql语句排序怎么按时间-SQL

SQL 语句按时间排序 在 SQL 中,您可以使用 ORDER BY 子句按时间对结果进行排序。 语法: SELECT column_name(s) FROM table_name ORDER BY...

sql游标怎么写-SQL

SQL 游标 什么是 SQL 游标? SQL 游标是一个用于管理和遍历结果集的结构。它允许应用程序从结果集中向上、向下或随机移动并检索数据。 如何写 SQL 游标? 声明游标: DECLARE cu...

发表评论

访客

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