首页 > 代码库 > 高性能索引-高性能索引策略二
高性能索引-高性能索引策略二
1.覆盖索引
索引是一种查找数据的高效方式,如果MySQL可以使用索引来直接获取列的数据,这样就不再需要读取数据行。如果一个索引包含所有需要查询的字段的值,就称之为“覆盖索引”。覆盖索引具有以下好处:
- 索引条目通常远小于数据行大小,所以如果只需要读取索引,就会极大的减少数据的访问。
- 索引是按列值顺序存储的,所以对I/O密集型的范围查询会比随机从磁盘读取每一行数据的I/O要少的多。
- 一些存储引擎如MyISAM在内存只会缓存索引。
- 由于InnoDB的聚族索引,覆盖索引对InnoDB非常有用。InnoDB的二级索引在叶子节点中保存了行的主键值,所以如果二级索引能够覆盖查询,则可以避免对主键索引的二次查询。
不是所有类型的索引都可以成为覆盖索引。覆盖索引必须要存储索引列的值,而哈希索引、空间索引和全文索引都不存储索引列的值,所以MySQL只能使用B-Tree索引做覆盖索引。
MySQL能够在索引中做最左前缀匹配的LIKE比较,因为该操作可以转换为简单的比较操作,但是如果是通配符开头的LIKE查询,存储引擎就无法匹配。
高性能索引-高性能索引策略二
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。