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

相关推荐
三翼鸟数字化技术团队9 分钟前
基于Redis ZSet实现分布式优先级队列的技术实践
java·redis
无所事事O_o17 分钟前
加密过程及原理浅析
java·加密
2301_7717172133 分钟前
最近在刷牛客:使用Spring AOP实现性能监控时
java·后端·spring
xcLeigh42 分钟前
IoTDB Rust 原生接口开发指南:从零生成 + 完整 RPC 调用
数据库·rpc·rust·接口·api·时序数据库·iotdb
华清远见成都中心1 小时前
C 语言内存管理深度解析:malloc/free 与嵌入式堆栈分配策略
java·c语言·算法
YANZ2221 小时前
亚马逊绿标(CPF):从环保认证到跨境流量新引擎
java·大数据·人工智能·搜索引擎·百度
努力努力再努力wz1 小时前
【MySQL 进阶系列】拒绝滥用root:从 mysql.user 到权限校验,带你彻底理解用户管理与授权机制!
android·c语言·开发语言·数据结构·数据库·c++·mysql
超梦dasgg1 小时前
智慧充电系统订单服务Java 实现方案
java·开发语言·微服务
JWASX1 小时前
【RocketMQ 生产者和消费者】- 事务源码分析(2)
java·rocketmq·java-rocketmq
eastyuxiao1 小时前
企业 OpenClaw 文档自动化落地项目 - 思维导图范围拆解
运维·自动化