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混用的坑的主要内容,如果未能解决你的问题,请参考以下文章
MySql 你知道 order by 是怎么回事吗? MySql全字段排序与 rowid 排序