mysql如何优化LIMIT深分页?延迟关联优化技巧有哪些

来源:网站主作者:上海GEO公司头衔:草根站长
导读:本期聚焦于小伙伴创作的《mysql如何优化LIMIT深分页?延迟关联优化技巧有哪些》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《mysql如何优化LIMIT深分页?延迟关联优化技巧有哪些》有用,将其分享出去将是对创作者最好的鼓励。

在mysql的业务查询场景中,分页查询是非常常见的需求,通常使用LIMIT关键字实现分页。但当偏移量不断增大形成深分页时,查询性能会出现明显下降,这时候就需要用到延迟关联等优化技巧来提升查询效率。

mysql如何优化LIMIT深分页?延迟关联优化技巧有哪些

LIMIT深分页的性能问题

我们先来看一个普通的分页查询语句,假设有一张用户表user,包含idnameagecreate_time等字段,其中id是主键,create_time有普通索引。

普通的深分页查询语句如下:

-- 查询第100001到100010条数据,偏移量为100000
SELECT id, name, age, create_time 
FROM user 
ORDER BY create_time DESC 
LIMIT 100000, 10;

这条语句的执行逻辑是:mysql会先按照create_time的索引排序,然后扫描前100010条记录,最后丢弃前100000条,只返回后面的10条。当偏移量很大时,需要扫描的数据量非常多,即使create_time有索引,也可能需要回表查询大量数据,导致性能低下。

延迟关联优化原理

延迟关联的核心思路是:先通过覆盖索引查询到需要的主键id,减少扫描的数据量,再用这些主键id去关联原表查询需要的字段,避免大量无效的数据扫描和回表操作。

因为覆盖索引只需要扫描索引树,不需要回表,速度会比全表扫描或者大量回表快很多。拿到主键id之后,再通过这些id去原表查询数据,这时候的查询是精准的主键查询,效率非常高。

延迟关联优化实现示例

还是以上面的用户表为例,我们用延迟关联优化上面的深分页查询:

-- 延迟关联优化后的查询语句
SELECT u.id, u.name, u.age, u.create_time
FROM (
    -- 子查询先通过覆盖索引拿到需要的主键id
    SELECT id 
    FROM user 
    ORDER BY create_time DESC 
    LIMIT 100000, 10
) AS tmp
-- 关联原表查询需要的字段
INNER JOIN user AS u ON tmp.id = u.id
ORDER BY u.create_time DESC;

我们拆解一下这个查询的执行步骤:

  • 第一步执行子查询,因为idcreate_time都在索引中,属于覆盖索引查询,只需要扫描索引树拿到100000到100010对应的10个id,不需要回表,扫描量大大减少。
  • 第二步用这10个id和原表做关联查询,这时候是原表的主键查询,每个id只需要一次回表操作,总共只需要10次回表,性能提升非常明显。

延迟关联的适用场景

延迟关联并不是所有分页场景都适用,它更适合以下场景:

  • 查询的偏移量比较大,普通LIMIT分页性能已经出现明显下降。
  • 排序的字段有索引,且子查询可以使用覆盖索引拿到主键id。
  • 查询的字段比较多,普通分页需要大量回表查询这些字段。

如果查询的字段本身就在排序索引中,属于覆盖索引查询,那么普通的分页查询性能已经足够,不需要使用延迟关联。

其他深分页优化方式

除了延迟关联,还有两种常见的深分页优化方式:

基于主键游标分页

如果主键是连续自增的,可以使用主键作为游标,避免偏移量查询:

-- 假设上一页最后一条数据的id是100000,查询下一页10条数据
SELECT id, name, age, create_time 
FROM user 
WHERE id < 100000 
ORDER BY id DESC 
LIMIT 10;

这种方式不需要扫描偏移量之前的数据,性能非常稳定,但是要求主键连续,且不能支持跳页查询。

使用标签记录位置

如果排序字段有唯一值,可以记录上一页最后一条数据的排序字段值,作为下一页查询的条件:

-- 假设上一页最后一条数据的create_time是2024-05-01 12:00:00,id是100000
SELECT id, name, age, create_time 
FROM user 
WHERE create_time < '2024-05-01 12:00:00' 
OR (create_time = '2024-05-01 12:00:00' AND id < 100000)
ORDER BY create_time DESC, id DESC 
LIMIT 10;

这种方式也可以避免大偏移量扫描,同样不支持跳页查询,适合连续翻页的场景。

优化方案对比

我们把几种常见的深分页优化方案做一个对比:

优化方案适用场景优点缺点
延迟关联大偏移量分页,支持跳页支持跳页,性能提升明显需要排序字段有索引,子查询能覆盖索引
主键游标分页主键连续,连续翻页性能最优,无扫描损耗不支持跳页,主键需要连续自增
标签记录位置连续翻页,排序字段唯一性能稳定,无大偏移量扫描不支持跳页,需要记录上一页最后一条数据

在实际业务中,可以根据具体的分页需求选择合适的优化方案,延迟关联是支持跳页场景下的最优选择,也是最常用的深分页优化技巧。

mysqllimit_深分页延迟关联sql优化分页查询修改时间:2026-06-26 18:00:38

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。