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

admin2年前 (2024-06-05)基础运维知识366
点击下载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 |
+----+----+
登录后复制

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

相关文章

mysql怎么导入数据库的文件-mysql教程

MySQL 导入数据库文件 如何导入数据库文件? 导入数据库文件到 MySQL 数据库可以通过以下步骤实现: 步骤 1:连接到数据库 使用 MySQL 命令行客户端或其他数据库工具连接到需要导入数据...

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

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

oracle解释计划怎么看-Oracle

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

sql备份数据库怎么看-SQL

查看 SQL 数据库备份的方法 要查看 SQL 数据库备份,可以采用以下步骤: 1. 确认备份存在 在 SQL Server Management Studio 中,连接到要查看备份的服务器。 在...

mysql版本号怎么查询-mysql教程

如何查询 MySQL 版本号 直接查询 最直接的方法是使用 SELECT VERSION() 语句: SELECT VERSION();登录后复制 此语句将返回 MySQL 服务器的完整版本号,包括...

sql分页查询语句怎么写-SQL

SQL 分页查询语句详解 分页查询是数据查询中常用的操作,它可以将查询结果分成多个页面,方便用户查看和操作。SQL 中分页查询的实现需要用到 LIMIT 和 OFFSET 子句。 语法: SELEC...

发表评论

访客

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