首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >LIMIT子句对MySQL中性能的影响?

LIMIT子句对MySQL中性能的影响?
EN

Stack Overflow用户
提问于 2013-03-28 04:21:52
回答 2查看 1.3K关注 0票数 2

我想我已经知道答案了,但是...

给定以下3条MySQL语句:

代码语言:javascript
复制
SELECT SQL_CALC_FOUND_ROWS title FROM STUFF LIMIT 1000000, 1;
SELECT SQL_CALC_FOUND_ROWS title FROM STUFF LIMIT 1;
SELECT title FROM STUFF;

这三种语言在性能上有显著差异吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-03-28 04:31:14

SQL_CALC_FOUND_ROWS需要遍历所有行来计算结果,因此1和2之间没有时间差(如果表中的行数少于1000000行,则第一个查询可能不会返回任何内容)

第三个查询将输出整个表,而不仅仅是计算它的行数。

票数 2
EN

Stack Overflow用户

发布于 2013-03-28 04:25:27

这取决于,如果您添加一个ORDER BY并对正在排序的列进行索引,那么它的速度会快得多。

这是因为它将在不扫描和排序完整结果集的情况下以方式执行。使用索引将产生索引范围扫描,该扫描将在生成所需数量的行时立即启动和停止。

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

https://stackoverflow.com/questions/15668660

复制
相关文章

相似问题

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