mysql同时使用order by排序和limit分页数据重复问题

目录

场景再现:

解决方案:

问题分析:

mysql官方描述:


场景再现:

最近排查数据时发现使用order by及limit分页时会出现不同页数数据重复问题及有的数据分页不会显示,但是按条件搜索就可以搜索出来。

解决方案:

排序中使用唯一值(例如主键id),保证每条数据不重复;

问题分析:

mysql官方描述:

如果多行在列中具有相同的值ORDER BY,服务器可以自由地以任何顺序返回这些行,并且可能会根据整体执行计划以不同的方式返回。换句话说,这些行的排序顺序相对于未排序的列是不确定的。

影响执行计划的一个因素是 LIMIT,因此ORDER BY 有和没有的查询LIMIT可能会以不同的顺序返回行。

也就是说如果我们order by 的字段值是一样的,那么每一次查询的数据返回可能的顺序是不同的。如果同limit一起使用,就可能出现分页数据重复的问题。

官方文档: MySQL :: MySQL 5.7 Reference Manual :: 8.2.1.17 LIMIT Query Optimization

由此可知,在同时使用order by及limit时尽量确保ORDER BY子句中包含其他列以使顺序具有​​确定性;

若按照时间排序,建议库中时间值精确到毫秒级别;

相关推荐
无奈笑天下30 分钟前
银河麒麟桌面OS使用分区编辑器将/backup分区删除并扩容至根分区参考教程
linux·数据库·经验分享·编辑器
tzhou644527 小时前
MySQL备份与恢复
数据库·mysql·adb
一过菜只因7 小时前
MySql Jdbc
android·数据库·mysql
思成不止于此7 小时前
MySQL 查询实战(三):排序与综合练习
数据库·笔记·学习·mysql
茅坑的小石头7 小时前
数据库表设计,概念模型、逻辑模型、物理模型的区别,目标、主要内容、所处阶段、面向人群,数据库无关性
数据库
tebukaopu1487 小时前
mysql数据备份还原
数据库·mysql
zyxqyy&∞8 小时前
mysql代码小练-2
数据库·mysql
JIngJaneIL8 小时前
基于Java非遗传承文化管理系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot
+VX:Fegn08958 小时前
计算机毕业设计|基于springboot + vue心理健康管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
poemyang8 小时前
像Git一样管理数据:深入解析数据库并发控制MVCC的实现
mysql·事务·mvcc