【mysql】1000w数据量的分页查询SQL,如何优化提升性能?

文章目录

优化场景

当表数据量非常大时,需要进行分页查询如果慢的时候,可以考虑优化下。

假设一页展示10条,查询第10w条后面的数据时候变慢了...
优化思路:先找到第10w+1条的位置,然后将这个位置作为where条件查询的起始位置进行查询。

示例:

普通分页SQL:

sql 复制代码
-- 从第6条查,查出5条

SELECT acct_code  FROM `tn_md_cust_base` limit 5,5

优化分页SQL:

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在之前也页码中已经出现了, 又在这里出现了一次。

相关推荐
一只叫煤球的猫2 分钟前
从1996到2025——细说Java锁的30年进化史
java·后端·性能优化
努力努力再努力wz4 分钟前
【Linux进阶系列】:线程(上)
java·linux·运维·服务器·数据结构·c++·redis
极客柒7 分钟前
Unity 协程GC优化记录
java·unity·游戏引擎
我要去腾讯9 分钟前
Springcloud核心组件之Sentinel详解
java·spring cloud·sentinel
czhc114007566310 分钟前
Java117 最长公共前缀
java·数据结构·算法
川石课堂软件测试15 分钟前
Python | 高阶函数基本应用及Decorator装饰器
android·开发语言·数据库·python·功能测试·mysql·单元测试
2301_8035545222 分钟前
面试后查缺补漏--cmake,makefiles,g++,gcc(自写精华版)
linux·运维·服务器
.又是新的一天.27 分钟前
08-Jmeter数据驱动、数据库的操作、命令行执行方式
数据库·jmeter
weixin_3077791342 分钟前
AWS Elastic Beanstalk 实现 Java 应用高可用部署指南
java·开发语言·云计算·aws·web app
Filotimo_1 小时前
springboot的单元测试功能有什么用
spring boot·单元测试·log4j