前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL排序字段数据相同不能分页问题

MySQL排序字段数据相同不能分页问题

作者头像
SmileNicky
发布2022-05-07 18:17:41
2.3K0
发布2022-05-07 18:17:41
举报
文章被收录于专栏:Nicky's blogNicky's blog

MySQL排序字段数据相同不能分页问题,最近同事遇到一个列表的分页有bug,点击第1行,第2行数据会出现重复的,初步怀疑是数据重复了,通过SQL查询,确认数据都没重复。

不过分页时候会出现重复,所以怀疑是分页问题,因为我之前遇到过order by的字段有null值的情况,排序也会有问题,所以通过经验去排查排序的字段数据,发现并没有null值的数据。

只是数据很多都是一样的,因为是通过批量导入的,新增时间都保存为一样的,然后分页再根据这个新增时间去排序,就会出现好像“数据重复”的现象

通过查询MySQL官方的资料,https://dev.mysql.com/doc/refman/5.7/en/limit-optimization.html,找到下面关键的信息:

If multiple rows have identical values in the ORDER BY columns, the server is free to return those rows in any order, and may do so differently depending on the overall execution plan. In other words, the sort order of those rows is nondeterministic with respect to the nonordered columns.

大致意思是,如果order by排序的字段有相同的数据,则服务器可以自由地以任何顺序返回这些行,并且可能会根据整体执行计划以不同的方式返回。

所以,问题就知道了,通过官网资料,可以知道可以在order by后面加上一个唯一的id

在这里插入图片描述
在这里插入图片描述
代码语言:javascript
复制
mysql> SELECT * FROM ratings ORDER BY category, id;
+----+----------+--------+
| id | category | rating |
+----+----------+--------+
|  1 |        1 |    4.5 |
|  5 |        1 |    3.2 |
|  3 |        2 |    3.7 |
|  4 |        2 |    3.5 |
|  6 |        2 |    3.5 |
|  2 |        3 |    5.0 |
|  7 |        3 |    2.7 |
+----+----------+--------+

mysql> SELECT * FROM ratings ORDER BY category, id LIMIT 5;
+----+----------+--------+
| id | category | rating |
+----+----------+--------+
|  1 |        1 |    4.5 |
|  5 |        1 |    3.2 |
|  3 |        2 |    3.7 |
|  4 |        2 |    3.5 |
|  6 |        2 |    3.5 |
+----+----------+--------+

当然,方法并非唯一,也可以新增数据时候,保证这个字段数据不相同,比如批量新增时间可以加1s,避免重复

通过网上资料,还找到可以加上索引的方法处理,这个问题虽然不是自己遇到过,不过挺有意思的,所以记录起来

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-04-07,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档