MySQL分页查询优化
- 一、背景
- 二、原因
- 三、解决
- 四、原理探究
https://blog.csdn.net/hollis_chuang/article/details/130570281
一、背景
- 业务背景:给C端10万级别的用户,同时发送活动消息,活动消息分为6类。
- 数据背景:mysql表有百万级别的数据量。
- 问题:每次发活动消息时,数据库占用过高
二、原因
看sql日志记录,明显看出有两个问题:
- 1 深分页
- 2 查询条件执行了两次
explain下
type类型为 ref
三、解决
- 原sql
select * from channel_subscribe_relation
where external_channel=9
and template_id = "dafdjlfanfdaln"
and subscribe_status=1
order by id ASC
LIMIT 50000,10
- 优化sql
SELECT * FROM channel_subscribe_relation
WHERE external_channel = 9 AND template_id = "dafdjlfanfdaln"AND subscribe_status = 1AND id > [Last_Page_Last_Id]
ORDER BY id ASC
LIMIT 10;
测试结果:
-
原sql: 平均 0.1s级别
-
优化sql:平均0.004 s
SELECT * FROM channel_subscribe_relation
WHERE external_channel = 9 AND template_id = "rNdk87qpBKQstZpx4hL0u1-kMCrF3phit-ySUOOt_8I"AND subscribe_status = 1AND id > 244567
ORDER BY id ASC
LIMIT 10;
综上所述,使用主键id索引替换分页查询 ,查询性能:缩短了近 25 倍。
四、原理探究
TODO