一、什么是覆盖索引
覆盖索引又称为索引覆盖,即 select 的数据列只从索引中就能得到,不必读取数据行,也就是只需扫描索引就可以得到查询结果。
- 使用覆盖索引,只需要从索引中就能检索到需要的数据,而不要再扫描数据表;
- 索引的体量往往要比数据表小很多,因此只读取索引速度会非常快,也会极大减少数据访问量;
- MySQL 的查询优化器会在执行查询前判断,是否有一个索引可以覆盖所有的查询列;
- 并非所有类型的索引都可以作为覆盖索引,覆盖索引必须要存储索引列的值。像哈希索引、空间索引、全文索引等并不会真正存储索引列的值。
二、如何判断使用了覆盖索引
当一个查询使用了覆盖索引,在查询分析器 EXPLAIN 的 Extra 列可以看到 “Using index”。