【发布时间】:2014-03-08 03:52:48
【问题描述】:
我有一个嵌套查询,我试图查看我的查询中是否有任何全表扫描。
explain delete from ACCESS where ACCESS.MESSAGEID in (select ID from MESSAGE where MESSAGE.CID = 'xzy67sd’)\G
子查询正在命中索引,但第一个查询没有使用索引。这是查询计划。
*************************** 1. row ***************************
id: 1
select_type: PRIMARY
table: ACCESS
type: ALL
possible_keys: NULL
key: NULL
key_len: NULL
ref: NULL
rows: 18295
Extra: Using where
*************************** 2. row ***************************
id: 2
select_type: DEPENDENT SUBQUERY
table: MESSAGE
type: unique_subquery
possible_keys: PRIMARY
key: PRIMARY
key_len: 8
ref: func
rows: 1
Extra: Using where
但是,如果我将查询分开并检查查询计划,那么它正在使用索引。我无法理解为什么并寻找一些提示
explain delete from ACCESS where ACCESS.MESSAGEID in (2,3)\G
*************************** 1. row ***************************
id: 1
select_type: SIMPLE
table: ACCESS
type: range
possible_keys: ACCESS_ID1
key: ACCESS_ID1
key_len: 8
ref: const
rows: 2
Extra: Using where
子查询 select 语句返回常量,所以我输入整数而不是使用 select 语句,查询计划开始选择索引
select ID from MESSAGE where MESSAGE.CID = 'xzy67sd’)\G
提前致谢
【问题讨论】: