学习笔记--mysql索引(五) 聚簇索引和覆盖索引

来源:互联网 发布:淘宝的二手手机可靠吗 编辑:程序博客网 时间:2024/05/18 03:25

一. 聚簇索引

聚簇索引并不是一种单独的索引类型,而是一种数据的存储方式。InnoDB的聚簇索引实际在同一个结构中保存了B树索引和数据行。也就是说,当表有聚簇索引时,它的数据行实际存放在索引的叶子页中。显然,由于无法把数据和放在两个不同的地方,一个表只能有一个聚簇索引。

对于InnoDB来说,默认使用主键作为聚簇索引,所以最好有一个与业务无关且自增的主键,这样会有比较好的插入和删除性能,也就是代理主键。

使用业务相关的主键的时候要非常小心,最好是该主键有一些聚集性和自增性,否则插入和删除可能性能非常低下。

二. 覆盖索引

覆盖索引的意思是一个索引包含了所有需要查询字段的值,这样查询就只需要扫描索引而不需要回表。

在explain的extra总看到“Using index”就表示使用了覆盖索引。

0 0
原创粉丝点击