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

相关推荐
一 乐1 小时前
婚纱摄影网站|基于ssm + vue婚纱摄影网站系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot·后端
Boilermaker19921 小时前
[Java 并发编程] Synchronized 锁升级
java·开发语言
Cherry的跨界思维1 小时前
28、AI测试环境搭建与全栈工具实战:从本地到云平台的完整指南
java·人工智能·vue3·ai测试·ai全栈·测试全栈·ai测试全栈
alonewolf_992 小时前
JDK17新特性全面解析:从语法革新到模块化革命
java·开发语言·jvm·jdk
一嘴一个橘子2 小时前
spring-aop 的 基础使用(啥是增强类、切点、切面)- 2
java
sheji34162 小时前
【开题答辩全过程】以 中医药文化科普系统为例,包含答辩的问题和答案
java
1.14(java)2 小时前
SQL数据库操作:从CRUD到高级查询
数据库
恋爱绝缘体12 小时前
2020重学C++重构你的C++知识体系
java·开发语言·c++·算法·junit
HIT_Weston3 小时前
93、【Ubuntu】【Hugo】搭建私人博客:面包屑(一)
linux·运维·ubuntu
wszy18093 小时前
新文章标签:让用户一眼发现最新内容
java·python·harmonyos