覆盖索引
基础解释
索引是高效找到行的一个方法,但是一般数据库也能使用索引找到一个列的数据,
因此它不必读取整个行。毕竟索引叶子节点存储了它们索引的数据;当能通过读
取索引就可以得到想要的数据,那就不需要读取行了。一个索引包含了(或覆盖了)
满足查询结果的数据就叫做覆盖索引。
ps:
它包括在查询里的Select、Join和Where子句用到的所有列(即建索引的字段
正好是覆盖查询条件中所涉及的字段,也即,索引包含了查询正在查找的数据)。
查看方法
explain sql语句:
extra (use index)有这个说明是覆盖索引
使用条件
索引必须存储列的值
ps:Hash 和full-text索引不存储值,因此MySQL只能使用B-TREE。
并且不同的存储引擎实现覆盖索引都是不同的。并不是所有的存储引擎
都支持它们。如果要使用覆盖索引。一定要注意SELECT 列表值取出需
要的列。不可以是SELECT * ,因为如果将所有字段一起做索引会导致
索引文件过大。查询性能下降。不能为了利用覆盖索引而这么做。
优点
MySQL只需要通过索引就可以返回查询所需要的数据,而不必在查到索
引之后进行回表操作,减少IO,提高了效率
网友评论