SQL UNION 操作符
SQL UNION
操作符用于合并两个或多个 SELECT
语句的结果集。它将多个结果集组合成一个单独的结果集,并去除重复的行。为了使用 UNION
,每个 SELECT
语句必须具有相同的列数,并且对应列的数据类型必须兼容。
语法
SELECT column_name(s) FROM table1
WHERE condition
UNION
SELECT column_name(s) FROM table2
WHERE condition;
示例
假设我们有两个表,employees_us
和 employees_eu
,它们分别存储美国和欧洲的员工信息。这两个表都有相同的结构,包括 id
、name
和 department
列。
-- 查询美国和欧洲所有不同部门的列表
SELECT department FROM employees_us
UNION
SELECT department FROM employees_eu;
UNION
与 UNION ALL
UNION
:默认行为,它会去除合并后的结果集中的重复行。UNION ALL
:不会去除重复行,只是简单地将所有结果合并在一起。它在性能上通常比UNION
更好,因为它不需要额外的步骤来识别和去除重复行。
注意事项
- 列数和数据类型:每个
SELECT
语句中的列数和数据类型必须相同。 - 结果集的列名:结果集的列名将取自第一个
SELECT
语句。 - 排序:
UNION
结果集默认不保证排序,如果需要排序,应在最后一个SELECT
语句后使用ORDER BY
。 - 性能:
UNION
通常比UNION ALL
慢,因为它需要额外的步骤来去除重复行。
高级应用
- 多个
UNION
:可以连续使用多个UNION
来合并多个结果集。 - 子查询:可以在
UNION
中使用子查询。 - 联合不同表的列:只要最终结果集的列数和数据类型相同,就可以联合不同表的列。
总结
UNION
是 SQL 中一个非常有用的操作符,它允许我们合并多个查询的结果集,并去除重复的行。它对于需要从多个表中获取数据,但又不想显示重复信息的情况特别有用。通过理解 UNION
的基本用法和注意事项,可以更有效地利用它在 SQL 查询中的强大功能。