MySQL 组合索引为何失效:查询选择所有列会导致索引失效?

mysql 组合索引为何失效:查询选择所有列会导致索引失效?

组合索引未生效:理解查询列对索引使用的影响

mysql 中,使用组合索引可以显着提升特定查询的性能。然而,有时组合索引可能无法生效,这可能是由查询的列决定的。

让我们考虑给定的问题:

explain select * from combine_indx where c = 3 and b = 4

该查询按 c 和 b 列查找记录。在表中,有一个组合索引覆盖这两种列。然而,执行 explain 时,sql 优化器未使用索引,而是选择了全表扫描 (all)。

原因在于该查询中使用了 select *,它将检索所有列(包括未包含在组合索引中的列),这迫使数据库回表以获取这些列的数据。回表会导致索引失效,因为需要扫描整个表来获取所需数据。

要解决此问题,可以修改查询以仅选择所需的列:

EXPLAIN SELECT b, c FROM combine_indx WHERE c = 3 and b = 4

通过只选择b 和c 列,查询不再需要回表,因此组合索引可以生效,这将导致索引查找(index) 而不是全表扫描(all) 的执行计划。

以上就是MySQL 组合索引为何失效:查询选择所有列会导致索引失效?的详细内容,更多请关注其它相关文章!