sql中的union和union all的区别-SQL

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

SQL 中 UNION 和 UNION ALL 的区别

UNION 和 UNION ALL 都是用于合并两个或多个表中的行的 SQL 操作符。然而,它们在处理重复行方面存在根本差异。

UNION

  • 仅返回结果表中唯一(不重复)的行。
  • 它在合并表之前会对各个表中的行进行去重。
  • 如果任意表中存在重复行,它们将仅出现在结果表中一次。

UNION ALL

  • 返回所有行,包括重复行。
  • 它不会对各个表中的行进行去重。
  • 如果任意表中存在重复行,它们将出现在结果表中多次。

示例

假设有两个表 T1 和 T2,如下所示:

T1:
+----+----+
| ID | Name |
+----+----+
| 1  | John |
| 2  | Susan |
| 3  | Mary |
+----+----+

T2:
+----+----+
| ID | Name |
+----+----+
| 2  | Susan |
| 4  | Bob |
+----+----+
登录后复制

如果使用 UNION 操作符合并这两个表:

SELECT * FROM T1 UNION SELECT * FROM T2;
登录后复制

结果将是:

+----+----+
| ID | Name |
+----+----+
| 1  | John |
| 2  | Susan |
| 3  | Mary |
| 4  | Bob |
+----+----+
登录后复制

其中,重复的行(ID = 2,Name = Susan)已被删除。

如果使用 UNION ALL 操作符合并这两个表:

SELECT * FROM T1 UNION ALL SELECT * FROM T2;
登录后复制

结果将是:

+----+----+
| ID | Name |
+----+----+
| 1  | John |
| 2  | Susan |
| 2  | Susan |
| 3  | Mary |
| 4  | Bob |
+----+----+
登录后复制

其中,重复行已包含在结果中。

相关文章

sql编辑数据怎么加一列-SQL

SQL 中添加一列 在 SQL 中,可以通过使用 ALTER TABLE 语句向现有表中添加一列。语法如下: ALTER TABLE table_name ADD column_name data_...

oracle解释计划怎么看-Oracle

如何解读 Oracle 解释计划 Oracle 解释计划是数据库提供的关于 SQL 语句执行计划的信息。它提供了对语句如何执行以及为什么以这种方式执行的深入见解。了解如何解读解释计划对于优化查询性能...

怎么查看mysql是否安装成功-mysql教程

如何验证 MySQL 是否成功安装? 为了验证 MySQL 是否成功安装,您可以按照以下步骤操作: 1. 打开终端或命令提示符 在您的操作系统上打开终端或命令提示符窗口。 2. 输入以下命令: &l...

mongodb与redis怎么选择-MongoDB

MongoDB 与 Redis 的选择 在选择数据库技术时,MongoDB 和 Redis 是两个流行的选择。选择合适的数据库取决于应用程序的特定需求。 用途 MongoDB: 面向文档的数据库...

sql插入语句怎么写-SQL

SQL 插入语句 在 SQL 中,插入数据到表中可以通过 INSERT INTO 语句来实现。该语句的基本语法如下: INSERT INTO table_name (column1, column2...

oracle重建索引怎么建的-Oracle

Oracle 重建索引的步骤 重建索引是一种维护数据完整性和提高查询性能的关键数据库操作。Oracle 中重建索引的步骤如下: 1. 禁用索引 使用 ALTER INDEX 命令禁用要重建的索引:...

发表评论

访客

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