mysql limit 分页原理_分页查询优化limit的方法和原理

一、背景

直接从数据库查询所有数据,耗时、耗内存,改为分页查询部分数据

二、常规分页查询

1.  mysql: limit 从第m条数据开始,查询n条数据

select * from table limit m,n

2. sql server: top+子查询

3. 原理:从数据库的第一条记录开始扫描

a. 越往后,即m越大,查询越慢

b. 查询的数据越多,即n越大,查询越慢

三、优化方式

1. 使用子查询进行优化,先查出一个id,再根据id进行limit,查出数据

2. 根据id做限定进行优化,把id作为where的条件

3. 使用临时表进行优化,先查出所有id,再试用in查出数据

select * from table where id in (select id from table limit m,n)

四、优化原理

1. select * from table limit m,n 的查询过程

a. 查询到索引叶子节点数据

b. 根据叶子节点上的主键值,去聚集索引,查询需要的全部字段值

379409729e768ddaa3f5358414c87fee.png

2. 优化后

46ca238f94a2e21246342bb282980bbb.png

参考:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值