SQL UNION 操作符

SQL UNION 操作符

SQL UNION 操作符用于合并两个或多个 SELECT 语句的结果集,它是一个非常有用的功能,特别是在需要从多个表中合并数据时。UNION 操作符要求每个 SELECT 语句必须有相同数量的列,列也必须有相似的数据类型。此外,每个 SELECT 语句的列顺序必须相同。

基本语法

SELECT column_name(s) FROM table1
UNION
SELECT column_name(s) FROM table2;

例子

假设我们有两个表,employeesmanagers,它们的结构如下:

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 语句之后。

结论

UNIONUNION ALL 是 SQL 中非常强大的工具,它们允许你轻松地合并来自不同表的数据,从而提供更全面的数据视图。正确使用这些操作符可以大大提高数据处理的效率和灵活性。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值