目录

你知道吗,MySQL 多字段排序有陷阱!

优秀的程序员必须注重细节。如果对细节不够了解,就一定会出现问题。回顾自己闯下的线上故障,我发现所有的问题都是疏忽在细节上。

这不,上周我差点又闯祸。,最近有一个新需求,允许用户一次性购买多份商品。开发过程很顺利,但在测试阶段,测试同事发现了一个问题,即履约记录的展示顺序出错了。在管理后台页面上,应该按照履约时间的倒序展示履约记录------也就是说,最近的履约记录应该显示在最前面。然而现在却展示成了正序,先显示几个月前的履约记录,这肯定是不对的。

我百思不得其解,因为我明明没有修改成正序,为什么会出问题呢?我急忙开始排查问题。

去掉一些无关的细节后,有问题的 SQL 大概是这样的。

❌ 错误的写法

sql 复制代码
Select * from perform_records Where user_id = #{userId} Order By created_time, id desc;

原本只需按照 created_time 倒序排序,但是当出现多条记录的 created_time 相同时,为了避免分页展示时重复展示的问题,我决定在排序字段中加入id。现在的排序字段变为 order by created_time, id desc,我的设想是先按照 created_time 倒序展示,如果 created_time 相同,则按照id 的倒序展示。

排序字段加上 id 后,变为Order By created_time, id desc;,我设想是先按照 created_time 倒序展示,如果 created_time 相同,则按照 id 倒序展示。

然而,结果却出乎意料,展示的效果完全相反,变成了按照履约时间的正序展示!

✅ 正确的写法

Order BY 支持多字段排序,如果选择多字段排序,则需要分别指定各字段的排序方式,如果不指定则默认为增序。

正确的办法是:分别指定 created_time 和 id 的排序方式。

Order By created_time desc , id desc;

因为我没有明确指定 created_time 的排序方式,默认采用了正序排列,导致了文章开头出现的问题。

我相信这个问题不仅我犯过,其他人也可能犯过类似的错误,过于自以为是地认为......

自从做互联网电商业务后,很久没有写复杂的 SQL,遇到复杂的 SQL 就得上百度搜一下。不知道大家有没有同感?

例如SQL 中的 ORDER BY 和 Limit 谁应该写前面?

本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
欧宸雅2 分钟前
Swift语言的游戏引擎
开发语言·后端·golang
uhakadotcom7 分钟前
阿里云RAM、用户、用户组、STS基础知识解读
后端·面试·github
Asthenia041212 分钟前
解析MQTT协议:开销更小、性能更强的,适用于IOT场景下的通讯协议
后端
一名用户16 分钟前
实用的alias别名命令——比2=1+1简单的基础命令
后端·shell
无名之逆31 分钟前
探索轻量高性能的 Rust HTTP 服务器框架 —— Hyperlane
服务器·开发语言·windows·后端·http·rust
uhakadotcom36 分钟前
阿里云RAM角色ARN和会话名称详解
后端·面试·github
uhakadotcom1 小时前
Javassist 入门指南:轻松操作 Java 字节码
后端·面试·github
霍珵蕴1 小时前
Kotlin语言的软件工程
开发语言·后端·golang
Asthenia04121 小时前
Java中Future的详细用法:异步and阻塞/-缺乏回调支持与异常处理有限
后端
无名之逆1 小时前
Hyperlane:高性能 Rust HTTP 服务器框架评测
服务器·开发语言·windows·后端·http·rust