%ign%ignore_a_1%re_a_1%分页查询的方法:1、用具体字段代替【*】;2、先查寻索引;3、使用【between … and】,id必须是连续递增的;4、保留上一页记录所在id。

mysql分页查询的方法:
简述
通常在MySQL中通过limit #{limit},#{offset}来进行分页查询。
当表中记录较多且页数(#{limit})较大时,分页查询效率变慢。
变慢的原因时,分页查询时,会先查询出limit + offset条记录,然后截取后面的offset记录。
本文以实际1.4亿的表big_table为例,记录如何优化分页查询。
测试说明
测试表:big_table,数据量:1.4亿。
原始SQL(4500ms)
-- 原始分页查询,耗时:4500msselect * from big_tablelimit 2000000,10;
慢的原因:
网龙b2b仿阿里巴巴电子商务平台
本系统经过多次升级改造,系统内核经过多次优化组合,已经具备相对比较方便快捷的个性化定制的特性,用户部署完毕以后,按照自己的运营要求,可实现快速定制会费管理,支持在线缴费和退费功能财富中心,管理会员的诚信度数据单客户多用户登录管理全部信息支持审批和排名不同的会员级别有不同的信息发布权限企业站单独生成,企业自主决定更新企业站信息留言、询价、报价统一管理,分系统查看分类信息参数化管理,支持多样分类信息,
0 查看详情
1、查询条件为*
2、limit = 2000000太大
优化一(推荐):用具体字段代替*(1600ms)
-- 用明确字段代替*,耗时:1600msselect id,uid,media_id,media_name,news_id,comment from big_tablelimit 2000000,10;
优化二:先查寻索引(450ms)
-- 方法1:先对索引进行分页查询,耗时:450msselect * from big_table AS h inner join (select id from big_table limit 2000000,10) AS ss on h.id = ss.id;-- 方法2:先查询出起始位置的索引,耗时:450msselect * from big_tablewhere id > (select id from big_table limit 2000000,1)limit 10;
优化三:between … and(5ms)
限制:id必须是连续递增的。
-- 上一页保留最后一条记录所在id,耗时:5msselect * from big_tablewhere id between 4882489 and 4882489 + 10 ;
优化四(推荐):保留上一页记录所在id(5ms)
限制:需要保留上一页的最后一条记录所在id
-- 上一页需要保留最后一条记录所在id,耗时:5msselect * from big_tablewhere id > 4882488limit 10;
更多相关免费学习推荐:mysql教程(视频)
以上就是mysql怎样实现分页查询的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1078067.html
微信扫一扫
支付宝扫一扫