聚簇索引和非聚簇索引关系

聚集索引和非聚集索引

什么是聚簇索引、非聚簇索引?

通俗的滴说:聚簇索引就是基于主键创建的索引,除了主键以外的其他索引被称为非聚簇索引,也叫二级索引!

在InnoDB引擎里面,一张表的数据对应的物理文件,本身就是按照B+树来组织的一种索引结构,而聚簇索引就是按照每一张表的主键来构建一颗B+树,然后叶子节点里面存储了这个表的每一行数据记录,所以基于InnoDB这样的一个特性聚簇索引,并不仅仅是一种索引类型还代表着一种数据的存储方式,同时也意味着每个表里面必须要有一个主键,如果没有主键InnoDB会默认选择或者添加一个隐藏列作为主键索引来存储这个表的数据行,一般情况下是建议使用自增id作为主键,这样的话id本身具有连续性,使得对应的数据也会按照顺序存储在磁盘上,写入性能和搜索的性能都很高,否测我们使用uuid这种随机id,那么在频繁插入数据的时候,就会导致随机磁盘IO,从而导致性能比较低!

InnoDB只能存在一个聚簇索引,原因很简单,如果存在多个聚簇索引,那么意味着这个表里面的数据会存在多个副本,造成磁盘空间浪费以及数据维护困难的问题!

由于在InnoDB里面主键索引表示的是一种数据存储结构,所以如果是基于非聚簇索引来查询一条完整记录最终还是需要访问主键索引来检索的。

如图所示:

在这里插入图片描述

以上就我个人的理解了!