背景:
分页查询排序后的数据,是一个很是常见的业务场景;但当使用不惟一的字段排序时,分两页查询的数据可能出现同一条数据,并丢失数据!mysql
示例:
一样的查询条件,offset不一样,居然取到了同一条数据?!sql
缘由解析(取自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便可;spa