Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/62.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
MySQL查询计划未使用索引_Mysql_Indexing - Fatal编程技术网

MySQL查询计划未使用索引

MySQL查询计划未使用索引,mysql,indexing,Mysql,Indexing,我有一个嵌套查询,我试图查看查询中是否有任何完整的表扫描 explain delete from ACCESS where ACCESS.MESSAGEID in (select ID from MESSAGE where MESSAGE.CID = 'xzy67sd’)\G 子查询正在命中索引,但第一个查询没有使用索引。这是查询计划 *************************** 1. row *************************** id

我有一个嵌套查询,我试图查看查询中是否有任何完整的表扫描

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语句,而是输入integer和查询计划开始选取索引

select ID from MESSAGE where MESSAGE.CID = 'xzy67sd’)\G 

提前感谢

在这里,您不需要子查询,作为一般规则,您不应该在MySQL中使用子查询,除非您确实需要子查询

DELETE a
  FROM ACCESS a
  JOIN MESSAGE m ON m.ID = a.MESSAGEID
 WHERE m.CID = 'xzy67sd’;
这将从ACCESS中删除行,而不显示消息,因为在
delete
from
之间只列出了ACCESS(通过其别名“a”),在此处您可以指定要从哪些表中删除匹配行

优化器应该适当地使用索引

(多表语法)