阿里巴巴爪哇代码公约中提到的,见https://yq.aliyun.com/articles/69327规则3.2.7
SELECT a.* FROM table1 a, (SELECT id FROM table1 WHERE condition LIMIT 100000, 20) b WHERE a.id = b.id比
SELECT * FROM table1 WHERE condition LIMIT 100000, 20本文解释了MySQL将获取100020行结果行,并消除前100000行,而不是只获取20行。
在MySQL查询引擎中是这样的吗?可能是缺陷还是缺陷?
更新
假设table1包含许多列(10+),且条件不太复杂(例如,ip LIKE '192.168.%')
发布于 2017-02-14 06:47:26
是的,这是真的。
第一个查询只扫描字段id的100020行结果行,然后扫描20行完整字段,而第二次查询扫描所有字段的结果行100020。
https://stackoverflow.com/questions/42219452
复制相似问题