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

相关推荐
神奇的程序员41 分钟前
从已损坏的备份中拯救数据
运维·后端·前端工程化
Goldn.1 小时前
Java核心技术栈全景解析:从Web开发到AI融合
java· spring boot· 微服务· ai· jvm· maven· hibernate
极限实验室1 小时前
APM(一):Skywalking 与 Easyearch 集成
数据库·云原生
ะัี潪ิื1 小时前
springboot加载本地application.yml和加载Consul中的application.yml配置反序列化LocalDate类型差异
spring boot·consul·java-consul
饕餮争锋1 小时前
SQL条件中WHERE 1=1 的功能
数据库·sql
虾..2 小时前
Linux 软硬链接和动静态库
linux·运维·服务器
Evan芙2 小时前
Linux常见的日志服务管理的常见日志服务
linux·运维·服务器
玄斎2 小时前
MySQL 单表操作通关指南:建库 / 建表 / 插入 / 增删改查
运维·服务器·数据库·学习·程序人生·mysql·oracle
李慕婉学姐2 小时前
【开题答辩过程】以《基于Android的出租车运行监测系统设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
java·后端·vue
m0_740043732 小时前
SpringBoot05-配置文件-热加载/日志框架slf4j/接口文档工具Swagger/Knife4j
java·spring boot·后端·log4j