SQL UNION 操作符
SQL UNION
操作符用于合并两个或多个 SELECT
语句的结果集,它是一个非常有用的功能,特别是在需要从多个表中合并数据时。UNION
操作符要求每个 SELECT
语句必须有相同数量的列,列也必须有相似的数据类型。此外,每个 SELECT
语句的列顺序必须相同。
基本语法
SELECT column_name(s) FROM table1
UNION
SELECT column_name(s) FROM table2;
例子
假设我们有两个表,employees
和 managers
,它们的结构如下:
employees:
+----+-------+--------+
| id | name | salary |
+----+-------+--------+
| 1 | Alice | 50000 |
| 2 | Bob | 60000 |
| 3 | Carol | 70000 |
+----+-------+--------+
managers:
+----+--------+--------+
| id | name | salary |
+----+--------+--------+
| 1 | David | 80000 |
| 2 | Eve | 90000 |
| 4 | Frank | 100000 |
+----+--------+--------+
如果我们想合并这两个表的数据,可以使用 UNION
:
SELECT name, salary FROM employees
UNION
SELECT name, salary FROM managers;
这将返回以下结果:
+-------+--------+
| name | salary |
+-------+--------+
| Alice | 50000 |
| Bob | 60000 |
| Carol | 70000 |
| David | 80000 |
| Eve | 90000 |
| Frank | 100000 |
+-------+--------+
注意,UNION
默认会去除重复的行。如果你想要包括重复的行,可以使用 UNION ALL
。
使用 UNION ALL
SELECT name, salary FROM employees
UNION ALL
SELECT name, salary FROM managers;
这将返回包括重复行的结果。
注意事项
UNION
操作符选择的是不同的值。UNION ALL
操作符允许重复的值。UNION
操作符不会对结果进行自动排序,如果你需要排序,应在最后一个SELECT
语句后使用ORDER BY
子句。ORDER BY
子句只能出现在最后一个SELECT
语句之后。
结论
UNION
和 UNION ALL
是 SQL 中非常强大的工具,它们允许你轻松地合并来自不同表的数据,从而提供更全面的数据视图。正确使用这些操作符可以大大提高数据处理的效率和灵活性。