贝利信息

sql中的union和union all的区别

日期:2024-05-02 00:00 / 作者:下次还敢
UNION仅返回唯一行,而UNION ALL包含重复行;UNION在合并前去重,UNION ALL不对行去重。

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 |
+----+----+

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