mysql进行分页查询数据不准确问题分析

背景:

新功能上线发现分页出现了问题,分析了一段时间发现是mysql的问题,mysql对字段相同值排序后再分页数据会不准确


问题描述:

例子使用的mysql版本是5.6.31

举个简单的例子,数据表t如下:

AB
11
22
33
44
55
62
72
82

进行下一页查询时

select A,B from t order by B limit 0,2; 

会出现:

AB
11
82

再进行下一页查询

select A,B from t order by B limit 2,2; 

会出现:

AB
32
82

再进行下一页查询

select A,B from t order by B limit 4,2; 

会出现:

AB
72
82

再进行下一页查询

select A,B from t order by B limit 6,2; 

会出现:

AB
44
55

可以看出,当b列的值为2时,mysql分页得到的数据和想要的数据并不匹配


原因分析:

在mysql中,如果排序的字段值都不同还好,这样分页不会出错,但是如果排序的字段值相同,那么mysql就不知道如何分页了,查询出的数据就会有问题。


解决方案:

看一下表中,是否还有不唯一的列值,将这个列也加入到排序中

这里可以将sql调整成

select A,B from t order by B,A limit 0,2; 

此时再进行分页,数据就不会出现问题了。

ps: 另外,这个问题与mysql的版本有关系,在5.1版本,针对有字段相同的数据排序分页并没有出现问题,但是5.6版本却有分页查询数据不准确的问题。

不管怎样,对多个字段排序再分页都是没问题的,所以,最好都仔细检查一下分页sql中是否有对字段进行排序,如果排了序,最好还是再添加排序字段,这样能保证不出问题。



相关:
https://www.cnblogs.com/itsoku123/p/11512508.html

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值