登录
首页 >  数据库 >  MySQL

Mysql 【order by 不唯一字段】与【limit】混用分析

来源:SegmentFault

时间:2023-02-24 20:28:48 126浏览 收藏

哈喽!今天心血来潮给大家带来了《Mysql 【order by 不唯一字段】与【limit】混用分析》,想必大家应该对数据库都不陌生吧,那么阅读本文就都不会很困难,以下内容主要涉及到MySQL,若是你正在学习数据库,千万别错过这篇文章~希望能帮助到你!

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

示例:

clipboard.png

同样的查询条件,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即可;

好了,本文到此结束,带大家了解了《Mysql 【order by 不唯一字段】与【limit】混用分析》,希望本文对你有所帮助!关注golang学习网公众号,给大家分享更多数据库知识!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表