Mysql order by 不唯一字段与limit混用的坑

Posted leeon_l

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mysql order by 不唯一字段与limit混用的坑相关的知识,希望对你有一定的参考价值。

背景:
分页查询排序后的数据,是一个非常常见的业务场景;但当使用不唯一的字段排序时,分两页查询的数据可能出现同一条数据,并丢失数据!

示例:

同样的查询条件,offset不同,竟然取到了同一条数据?!

原因解析(取自Mysql官方文档):

上面官方文档里面有提到如果你将Limit row_count与order by混用,mysql会找到排序的row_count行后立马返回,而不是排序整个查询结果再返回。如果是通过索引排序,会非常快;如果是文件排序,所有匹配查询的行(不带Limit的)都会被选中,被选中的大多数或者全部会被排序,直到limit要求的row_count被找到了。如果limit要求的row_count行一旦被找到,Mysql就不会排序结果集中剩余的行了。(此段取自网络)

总结(取自Mysql官方文档):

当排序和分页结合时,一定要非常警觉,order by 后应采用唯一的字段或字段组合,如:在上例中采用order by sku_id,id即可;

博客搬家:https://segmentfault.com/blog/leeonfancy

以上是关于Mysql order by 不唯一字段与limit混用的坑的主要内容,如果未能解决你的问题,请参考以下文章

oracle 分页 有无order by情况不同吗

MySQL ORDER BY 字段与切换

MySql 你知道 order by 是怎么回事吗? MySql全字段排序与 rowid 排序

MySql 你知道 order by 是怎么回事吗? MySql全字段排序与 rowid 排序

Mysql order by与limit混用陷阱

mysql order by 与 limit 混用陷阱