当前位置: 首页 > news >正文

MySQL中的UNION和UNION ALL【简单易懂】

一、前言

  • UNION 和 UNION ALL 是 SQL 中用于合并多个查询结果集的关键字。

二、核心作用

  • 两者均用于将多个 SELECT 语句的结果集纵向合并(列结构需相同),但行为存在关键差异:
    在这里插入图片描述

三、使用场景对比

  • 需要去重时:例如合并两个客户表且避免重复记录
SELECT customer_id FROM table1
UNION
SELECT customer_id FROM table2;
  • 需保留重复数据或追求性能时:例如统计日志数据时需保留所有条目
SELECT log_time FROM debug_logs
UNION ALL
SELECT log_time FROM error_logs;

四、关键注意事项

  • 列结构一致性
    • 列数量、对齐顺序必须严格一致。
    • 数据类型需兼容(如 VARCHAR 和 TEXT 可合并,但 INT 和 DATE 会报错)。
  • 排序与别名
    • 若需最终排序,仅在最后一个 SELECT 后加 ORDER BY:
SELECT name FROM employees
UNION ALL
SELECT name FROM contractors
ORDER BY name;  -- 整体排序
  • 列名以第一个 SELECT 语句指定的字段别名为准。

五、示例

  • student表结构如下:
    在这里插入图片描述

  • score表结构如下:
    在这里插入图片描述

1.UNION查询结果

在这里插入图片描述

2.UNION ALL查询结果

在这里插入图片描述

六、总结

  • UNION:适合数据去重场景,牺牲性能换取数据唯一性
  • UNION ALL:适合数据全量合并或性能敏感场景,尤其在大数据量时优先考虑。
  • 实际使用时需根据数据特性和业务需求权衡选择。

相关文章:

  • 深入解析@Validated注解:Spring 验证机制的核心工具
  • 层归一化(Layer Normalization) vs 批量归一化(Batch Normalization)
  • mysql 有哪些存储引擎、区别是什么
  • 行星际激波在日球层中的传播:Propagation of Interplanetary Shocks in the Heliosphere (第二部分)
  • Maven工具学习使用(十一)——部署项目到仓库
  • 3.4 函数单调性与曲线的凹凸性
  • 欢乐力扣:删除链表的倒数第n个节点
  • vue @import引入CSS scoped无效 造成全局样式污染
  • 【LeetCode 热题100】二叉树遍历入门:从中序遍历到层序与右视图(力扣94 / 102/199)(Go语言版)
  • 【今日三题】小易的升级之路(模拟+gcd) / 礼物的最大价值(动态规划) / 对称之美(字符串哈希)
  • 50道SQL练习题
  • HarmonyOS:Map Kit简介
  • ocr-不动产权识别
  • AI推理强,思维模型也有功劳【57】复利效应
  • 基于 RabbitMQ 优先级队列的订阅推送服务详细设计方案
  • flutter 桌面应用之窗口自定义
  • 【Ubuntu】【树莓派】Linux系统的远程终端登录、远程图形桌面访问、 X图形窗口访问和文件传输操作
  • PHP防火墙代码,防火墙,网站防火墙,WAF防火墙,PHP防火墙大全
  • 程序化广告行业(83/89):行业术语与4A广告代理公司解析
  • idea 2024 build菜单不见了
  • 董明珠孟羽童官宣,5月23日将合体直播
  • 牛市早报|央行:加力支持提振消费、稳定外贸等领域,用好用足存量增量政策
  • 广西隆林发生一起山洪灾害,致4人遇难
  • 上海婚登人聂晶:见证爱情故事开启,也向长久婚姻致敬
  • 国家发改委谈整治“内卷式”竞争:加力破除地方保护和市场分割,遏制落后产能无序扩张
  • 人民日报任平:从“地瓜经济”理论到民营经济促进法,读懂中国经济的成长壮大之道