覆盖索引
1.什么是覆盖索引?
概念:查询语句中所需要的列在索引中,这样查询结果在索引的数据结构中查找即可拿到结果。
附加网友解释:
- 解释一: 就是select的数据列从索引中就能够获取,不必从数据表中再次读取,换句话说,就是查询列可以索引福噶
- 解释二:索引是高效找到行的一个方法,当能通过检索索引就可以读取想要的数据,那就不需要再到数据表中读取行了。如果一个索引包含了(或覆盖了)满足查询语句中字段与条件的数据就叫做覆盖索引。
- 解释三:是非聚集组合索引的一种形式,它包括在查询里的select,join和where子句用到的所有列(即建立索引的字段正好是覆盖查询语句[select子句]与查询条件[where子句]中所涉及的字段,也即,索引包含了查询正在查找的所有数据)。
2.形成覆盖索引的条件
索引分为多种类型,从数据结构上分为 二叉树、红黑树、 Hash索引、B-Tree索引,B+Tree(MySQL使用的存储结构)
索引的实现可以使用多种数据结构,这里使用B-Tree和B+Tree的索引能实现覆盖索引。
3.如何查看是否使用了覆盖索引?
使用
explain
命令,通过查看Extra
列可以看到Using index
的信息,证明使用了覆盖索引
4.如何使用覆盖索引优化SQL
先扯出来一个概念
回表:先索引扫描,再通过ID去查表数据,取索引中未能提供的数据,即为回表。
简单来说就是数据库根据索引找到了指定的记录所在行后,还需要根据rowid再次到数据块里取数据的操作
如何避免回表?
条件允许的情况下,使用联合索引
- 使用
explain
命令,Extra
列出现Using index condition
表示使用的索引方式为二级检索,数据将会被回表查询,会出现一定的性能消耗。 - 分页查询时,通过
组合索引
,能够实现覆盖索引
.
5.总结
对于覆盖索引
,通过联合索引可能实现覆盖索引,但是该情况只限于对于所需的查询列比较少的情况,所需的查询列比较多的情况,不可能全部实现联合索引
,所以不能实现覆盖索引。