覆盖索引

覆盖索引

基础解释

索引是高效找到行的一个方法,但是一般数据库也能使用索引找到一个列的数据,  
因此它不必读取整个行。毕竟索引叶子节点存储了它们索引的数据;当能通过读  
取索引就可以得到想要的数据,那就不需要读取行了。一个索引包含了(或覆盖了)  
满足查询结果的数据就叫做覆盖索引。  
ps:
它包括在查询里的Select、Join和Where子句用到的所有列(即建索引的字段  
正好是覆盖查询条件中所涉及的字段,也即,索引包含了查询正在查找的数据)。

查看方法

explain sql语句:  
  extra  (use index)有这个说明是覆盖索引

使用条件

索引必须存储列的值   

ps:Hash 和full-text索引不存储值,因此MySQL只能使用B-TREE。
并且不同的存储引擎实现覆盖索引都是不同的。并不是所有的存储引擎  
都支持它们。如果要使用覆盖索引。一定要注意SELECT 列表值取出需  
要的列。不可以是SELECT * ,因为如果将所有字段一起做索引会导致
索引文件过大。查询性能下降。不能为了利用覆盖索引而这么做。

优点

MySQL只需要通过索引就可以返回查询所需要的数据,而不必在查到索  
引之后进行回表操作,减少IO,提高了效率
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一、覆盖索引覆盖索引(covering index)指一个查询语句的执行只用从索引中就能够取得,不必从数据表中读取...
    wuxuan94阅读 25,936评论 5 21
  • MySQL覆盖索引 1.定义: 一个索引包含(或者覆盖)所有需要查询的字段
    BarryPro阅读 218评论 0 1
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,080评论 19 139
  • 强军征程起 开训战鼓鸣 苦练精兵魂 精忠报国心
    大吕同志阅读 232评论 0 0