【mysql】1000w数据量的分页查询SQL,如何优化提升性能?
温馨提示:这篇文章已超过438天没有更新,请注意相关的内容是否还可用!
文章目录
- 优化场景
- 特别注意!!!有前提,谨慎使用
优化场景
当表数据量非常大时,需要进行分页查询如果慢的时候,可以考虑优化下。
假设一页展示10条,查询第10w条后面的数据时候变慢了…
优化思路:先找到第10w+1条的位置,然后将这个位置作为where条件查询的起始位置进行查询。
示例:
普通分页SQL:
-- 从第6条查,查出5条 SELECT acct_code FROM `tn_md_cust_base` limit 5,5
优化分页SQL:
-- 先找到第6条编码位置,作为比较条件,从这个位置开始查询,查5条 SELECT acct_code FROM `tn_md_cust_base` where acct_code >= (select acct_code from tn_md_cust_base limit 5, 1) limit 0,5
特别注意!!!有前提,谨慎使用
需要看一下表索引,或者后续是否会加其他索引,索引是否会对默认SQL结果排序造成影响。
大白话来说:
就是比如上面的 tn_md_cust_base 表有1000w条数据,分页查询第 100w - 101w 数据时,先要确保默认 select 查询是根据 acct_code 这个条件字段排序的,且这个字段是递增的,否则找到 100w + 1 的位置,作为条件查比它大的条目的时候,就有可能出现条目A在之前也页码中已经出现了, 又在这里出现了一次。
免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!


