Mysql 优化 limit
2022/5/22 10:51:12
本文主要是介绍Mysql 优化 limit,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
一、分页原理
在探讨 Mysql 分页原理之前,我们先看一下几条关于分页的 Sql
从上面的 Sql 可以看出,随着分页的起始位置增大,分页的耗时也在不断增大,当进行最后一页分页的时候,耗时达到最大
那么为什么每一页耗时不一样呢,越往后翻页需要的时间越久呢?
针对于 limit m,n 这种分页语句,Mysql 会先查找出前 m + n 条记录,然后将前 m 条记录丢弃,只保留 n 条记录
例如 limit 1000,10 ,Mysql 会先找出前 1010 条记录,而结果仅仅需要返回第 1001 到 1010 的记录行,那么前 1000 条记录都会被抛弃,整个分页的代价还是很大的
二、如何优化分页
1、尽可能扫描少的数据
先看两条 Sql
// 优化前 select * from t2 limit 2999990,10; // 优化后 select t2.* from t2 inner join (select id from t2 limit 2999990,10)temp on t2.id = temp.id;
查看两条 Sql 的耗时情况,一个耗时 0.94 s,优化后耗时 0.54 s,性能还是有提升的
查看执行计划分析
为什么第二条 Sql 会比第一条 Sql 耗时短呢
第一条 Sql 全表扫描聚集索引叶子节点的所有记录行
第二条 Sql 先全表扫描聚集索引的索引,获取到包含10 个 id 的衍生表 temp,然后使用 temp 表作为驱动表去关联 t2 表获取完整的数据
2、传上一次分页的最大 id 标识
假设上一页返回的最大 id 为 2999990
这种分页就是把 limit m,n 转换成 limit m,但是这种分页存在局限性,例如在分页的过程中在前面删除了两条数据,得到的结果就不一致了
这篇关于Mysql 优化 limit的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-04部署MySQL集群项目实战:新手入门教程
- 2024-11-04如何部署MySQL集群资料:新手入门指南
- 2024-11-02MySQL集群项目实战:新手入门指南
- 2024-11-02初学者指南:部署MySQL集群资料
- 2024-11-01部署MySQL集群教程:新手入门指南
- 2024-11-01如何部署MySQL集群:新手入门教程
- 2024-11-01部署MySQL集群学习:新手入门教程
- 2024-11-01部署MySQL集群入门:新手必读指南
- 2024-10-23BinLog入门:新手必读的MySQL二进制日志指南
- 2024-10-23Binlog入门:MySQL数据库的日志管理指南