limit offset较大时,
select * from user limit 10000,10 和
select * from user limit 0,10
执行效率差别较大。原因是limit10000,10的意思扫描满足条件的10010行,扔掉前面的10000行,返回最后的10行(全表扫描)。
优化:
select * from (
select id from user
order by id limit 10000,10
) a
left join user b on a.id=b.id
注意,如果有where字段需做复合索引,否则的话效果提升不明显。
select * from user limit 10000,10 和
select * from user limit 0,10
执行效率差别较大。原因是limit10000,10的意思扫描满足条件的10010行,扔掉前面的10000行,返回最后的10行(全表扫描)。
优化:
select * from (
select id from user
order by id limit 10000,10
) a
left join user b on a.id=b.id
注意,如果有where字段需做复合索引,否则的话效果提升不明显。
当使用LIMIT和OFFSET进行大量数据偏移查询时,效率会显著下降。本文介绍了一种通过子查询优化的方法来提高此类查询的性能,并强调了正确使用索引的重要性。
384

被折叠的 条评论
为什么被折叠?



