mysql学习教程,从入门到精通,SQL UNION 运算符(27)

1、SQL UNION 运算符

UNION 运算符在 SQL 中用于合并两个或多个 SELECT 语句的结果集,并默认去除重复的行。如果你想要包含所有重复行,可以使用 UNION ALL。下面是一个使用 UNION 运算符的示例,假设我们有两个表:employees_2020employees_2021,它们存储了不同年份的员工信息,每个表都有 employee_id(员工ID)和 employee_name(员工姓名)两个字段。

1.1、示例场景

我们想要查询 2020 年和 2021 年所有员工的姓名,但不希望结果中出现重复的员工姓名。

表结构

employees_2020

employee_id employee_name
1 Alice
2 Bob
3 Charlie

employees_2021

employee_id employee_name
2 Bob
3 Charlie
4 David

1.2、SQL 查询

sql 复制代码
SELECT employee_name
FROM employees_2020
UNION
SELECT employee_name
FROM employees_2021;

结果

employee_name
Alice
Bob
Charlie
David

解释

这个查询通过 UNION 合并了两个 SELECT 语句的结果集:第一个从 employees_2020 表中选择 employee_name,第二个从 employees_2021 表中选择 employee_name。由于 UNION 默认去除重复行,所以尽管 BobCharlie 在两个表中都出现,但在最终的结果集中只出现一次。

注意

  • 如果你的目的是包含所有重复行,应使用 UNION ALL 替代 UNION
  • UNION 要求每个 SELECT 语句中的列数必须相同,并且对应列的数据类型也需要兼容。
  • 在使用 UNION 时,默认情况下,SQL 会对结果集进行排序以去除重复项,这可能会影响查询性能。如果不需要排序或去重,使用 UNION ALL 可以提高性能。
  • 可以在 UNIONUNION ALL 后添加 ORDER BY 语句来对最终结果集进行排序。但请注意,ORDER BY 语句应放在最后一个 SELECT 语句之后,并且对所有合并后的列都有效。
    UNION 运算符在 SQL 中有广泛的用途,主要用于合并两个或多个 SELECT 语句的结果集。以下是一些常见的用途和例子:

1. 3、合并来自不同表的数据

这是 UNION 最直接的用途。当你想要从两个或多个具有相似结构(即列数相同且对应列的数据类型兼容)的表中检索数据时,可以使用 UNION 来合并这些表的结果。
例子

假设有两个表,sales_2020sales_2021,分别记录了 2020 年和 2021 年的销售数据,每个表都有 product_idsales_amount 字段。

sql 复制代码
SELECT product_id, sales_amount
FROM sales_2020
UNION
SELECT product_id, sales_amount
FROM sales_2021;

这个查询将返回 2020 年和 2021 年所有产品的销售金额,但不包括重复的产品(如果某个产品在两年中都有销售记录,则只会出现一次)。

1.4. 合并具有不同条件的查询结果

有时,你可能想要从同一个表中检索数据,但基于不同的条件。使用 UNION 可以将这些基于不同条件的查询结果合并为一个结果集。
例子

假设有一个 employees 表,包含员工的姓名(name)和部门(department)信息。你想要检索所有在"销售"部门或"市场"部门的员工姓名。

sql 复制代码
SELECT name
FROM employees
WHERE department = '销售'
UNION
SELECT name
FROM employees
WHERE department = '市场';

3. 跨数据库合并数据

虽然 UNION 本身是在单个数据库查询中使用的,但你可以通过数据库链接(如 Oracle 的数据库链接或 SQL Server 的链接服务器)来跨数据库合并数据。这通常涉及到更复杂的查询,但基本思想是相同的:从不同的数据源检索数据,并使用 UNION(或 UNION ALL)来合并结果。

4. 报告和数据分析

在生成报告或进行数据分析时,经常需要合并来自不同表或不同查询的数据集。UNION 允许你将这些数据集合并为一个,便于进一步的分析或报告生成。

5. 去除重复数据

虽然 UNION 的主要目的不是专门为了去除重复数据(因为那是它的默认行为),但在某些情况下,这正是你想要的。如果你想要从多个表中检索数据,并且只关心唯一的记录,那么 UNION 是一个很好的选择。

注意事项

  • 当使用 UNION 时,每个 SELECT 语句中的列数必须相同,并且对应列的数据类型也需要兼容。
  • UNION 默认去除重复的行。如果你想要包含所有重复的行,应该使用 UNION ALL
  • 可以在 UNIONUNION ALL 后面添加 ORDER BY 语句来对最终结果集进行排序,但 ORDER BY 必须位于最后一个 SELECT 语句之后。
  • 在某些情况下,使用 JOIN 而不是 UNION 可能更合适,特别是当你想要根据两个表之间的关系来合并数据时。然而,JOINUNION 在用途上是不同的,JOIN 用于基于相关列合并行的数据,而 UNION 用于合并不同的结果集。
相关推荐
jack_xu21 分钟前
高频面试题:如何保证数据库和es数据一致性
后端·mysql·elasticsearch
264玫瑰资源库22 分钟前
问道数码兽 怀旧剧情回合手游源码搭建教程(反查重优化版)
java·开发语言·前端·游戏
技术项目引流36 分钟前
elasticsearch查询中的特殊字符影响分析
大数据·elasticsearch·搜索引擎
EasyDSS1 小时前
视频监控从安装到优化的技术指南,视频汇聚系统EasyCVR智能安防系统构建之道
大数据·网络·网络协议·音视频
普if加的帕1 小时前
java Springboot使用扣子Coze实现实时音频对话智能客服
java·开发语言·人工智能·spring boot·实时音视频·智能客服
施嘉伟1 小时前
Oracle 11g RAC ASM磁盘组剔盘、加盘实施过程
数据库·oracle
lilye661 小时前
精益数据分析(20/126):解析经典数据分析框架,助力创业增长
大数据·人工智能·数据分析
苏小夕夕1 小时前
spark-streaming(二)
大数据·spark·kafka
珈和info1 小时前
珈和科技助力“农险提效200%”!“遥感+”技术创新融合省级示范项目荣登《湖北卫视》!
大数据·科技·无人机·智慧农业
盈达科技1 小时前
盈达科技:登顶GEO优化全球制高点,以AICC定义AI时代内容智能优化新标杆
大数据·人工智能