首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么带有子查询的MySQL限制条件搜索比简单搜索更快?

为什么带有子查询的MySQL限制条件搜索比简单搜索更快?
EN

Stack Overflow用户
提问于 2017-02-14 06:38:00
回答 1查看 52关注 0票数 0

阿里巴巴爪哇代码公约中提到的,见https://yq.aliyun.com/articles/69327规则3.2.7

代码语言:javascript
复制
SELECT a.* FROM table1 a, (SELECT id FROM table1 WHERE condition LIMIT 100000, 20) b WHERE a.id = b.id

代码语言:javascript
复制
SELECT * FROM table1 WHERE condition LIMIT 100000, 20

本文解释了MySQL将获取100020行结果行,并消除前100000行,而不是只获取20行。

在MySQL查询引擎中是这样的吗?可能是缺陷还是缺陷?

更新

假设table1包含许多列(10+),且条件不太复杂(例如,ip LIKE '192.168.%')

EN

回答 1

Stack Overflow用户

发布于 2017-02-14 06:47:26

是的,这是真的。

第一个查询只扫描字段id的100020行结果行,然后扫描20行完整字段,而第二次查询扫描所有字段的结果行100020。

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

https://stackoverflow.com/questions/42219452

复制
相关文章

相似问题

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