gpt4 book ai didi

MySQL 查询计划不使用索引

转载 作者:行者123 更新时间:2023-11-29 13:09:39 24 4
gpt4 key购买 nike

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

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 

提前致谢

最佳答案

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

DELETE a
FROM ACCESS a
JOIN MESSAGE m ON m.ID = a.MESSAGEID
WHERE m.CID = 'xzy67sd’;

这将从 ACCESS 中删除行,同时保留 MESSAGE,因为在 DELETEFROM 之间仅列出 ACCESS(通过其别名“a”),这是您可以在其中列出的行指定要从中删除匹配行的表。

优化器应该适本地使用索引。

https://dev.mysql.com/doc/refman/5.6/en/delete.html (多表语法)

关于MySQL 查询计划不使用索引,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22264788/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com