ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

Mysql 优化 limit

2022-05-21 22:00:58  阅读:169  来源: 互联网

标签:分页 Mysql t2 耗时 limit Sql 优化 id


一、分页原理

在探讨 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,t2,耗时,limit,Sql,优化,id
来源: https://www.cnblogs.com/xiaomaomao/p/16296159.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有