首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MySQL:如何优化在多列索引上具有"order by“的SQL脚本的分页?

MySQL:如何优化在多列索引上具有"order by“的SQL脚本的分页?
EN

Stack Overflow用户
提问于 2021-03-18 11:44:18
回答 1查看 31关注 0票数 2

我们知道

代码语言:javascript
复制
select * from table order by id limit 1000000,10

可以通过这种方式进行优化

代码语言:javascript
复制
select * from table where id > (select id from table  order by id limit 1000000,1) limit 10

但是如果我们使用像idx_ab (a,b)这样的多列索引,如何优化下面的sql命令呢?

代码语言:javascript
复制
select * from table order by a,b limit 1000000,10
EN

回答 1

Stack Overflow用户

发布于 2021-03-19 09:26:16

代码语言:javascript
复制
select * from table order by a,b limit 1000000,10

将在这个综合索引的帮助下进行某种程度上的优化:INDEX(a,b)

但是,它必须遍历1000000行,一次一行,然后才能找到所需的10行。这是非常低效的,无论索引中有多少列,等等。

一些“分页”应用程序可以通过“记住你离开的地方”来加快速度,正如这里所讨论的:http://mysql.rjweb.org/doc.php/pagination它还提供了一个当键是复合键时如何执行此操作的链接。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66684442

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档