踩坑无数!MySQL UNION和ORDER BY混用的血泪教训,看完不再翻车

摘要

本文介绍MySQL中使用union多个子集导致排序失效的场景如何解决。

失效场景复现

目的

想先让A表按id升序,再让B表按id降序,然后拼在一起,最终想保证顺序一致

sql 复制代码
(SELECT id, name FROM A ORDER BY id ASC)
UNION
(SELECT id, name FROM B ORDER BY id DESC);

结果

A或B内单独查询顺序无误,但UNION后排序反而乱了...

原因

mysql8.0官方给的解释是:UNION分支里的ORDER BY会被优化器直接扔掉,想让单个分支先排好序,必须在该分支里再加一个LIMIT任意大数,并且最后把整个UNION再包一层SELECT,在最外层写ORDER BY。

正确写法

  • 多子集排序字段一致:
vbnet 复制代码
SELECT * FROM (
  SELECT id, name, 1 AS seq    -- 用常量列保住先后顺序
  FROM A
  ORDER BY id ASC
  LIMIT 99999999    -- 必须加LIMIT,否则ORDER BY会被优化掉
) a
UNION
SELECT * FROM (
  SELECT id, name, 2 AS seq
  FROM B
  ORDER BY id DESC
  LIMIT 99999999
) b
ORDER BY seq, id;    -- 外层再按需要整体排序
  • 多子集排序字段不一致:
vbnet 复制代码
SELECT * FROM (
  SELECT id, create_time, 1 AS seq    -- 用常量列保住先后顺序
  FROM table_A
  ORDER BY create_time ASC
  LIMIT 99999999    -- 必须加LIMIT,否则ORDER BY会被优化掉
) a
UNION
(
  SELECT id, create_time, 2 AS seq
  FROM table_B
  ORDER BY id DESC
  LIMIT 99999999
) b
ORDER BY seq;    -- 仅保证先A后B,不再对内部二次排序

总结

以上我们了解了mysql中union多个子集时防止子集内的排序失效的做法,子集写limit,外层再包含,最终再order。

关注公众号:咖啡Beans

在这里,我们专注于软件技术的交流与成长,分享开发心得与笔记,涵盖编程、AI、资讯、面试等多个领域。无论是前沿科技的探索,还是实用技巧的总结,我们都致力于为大家呈现有价值的内容。期待与你共同进步,开启技术之旅。

相关推荐
言德斐9 小时前
SQL性能优化的思路及策略
数据库·sql·性能优化
码界奇点10 小时前
Django视图从基础到高级的全面解析
数据库·django·sqlite·web·python3.11
Allan_202510 小时前
数据库学习
数据库·学习
fen_fen10 小时前
人大金仓数据库kingbase8创建表示例
数据库·oracle
一勺菠萝丶10 小时前
「您的连接不是私密连接」详解:为什么 HTTPS 证书会报错,以及如何正确配置子域名证书
数据库·网络协议·https
²º²²এ松10 小时前
蓝牙低功耗(BLE)通信的中心设备/外围设备(连接角色)、主机/从机(时序角色)、客户端/服务器(数据交互角色)的理解
运维·服务器·数据库
百锦再11 小时前
Vue Scoped样式混淆问题详解与解决方案
java·前端·javascript·数据库·vue.js·学习·.net
数据库知识分享者小北11 小时前
云栖重磅|瑶池数据库:从云原生数据底座向“AI就绪”的多模态数据底座演进
数据库·人工智能·云原生
_Johnny_11 小时前
Redis 升级操作指南:单机与主从模式
数据库·redis·缓存
源力祁老师12 小时前
ODOO数据文件(XML、CSV、SQL)是如何转换并加载到 Odoo 数据库
xml·数据库·sql