MySQL 专题

三分钟介绍 MySQL 聚簇索引

2024-04-26  本文已影响0人  onnoA

聚簇索引

聚簇索引并不是一种单独的索引类型,而是一种数据存储方式(所有的用户记录都存储在了叶子节点),也就是所谓的索引即数据,数据即索引

术语"聚簇"表示数据行和相邻的键值聚簇的存储在一起。

特点:

  1. 使用记录主键值的大小进行记录和页的排序,这包括三个方面的含义:

    • 页内的记录是按照主键的大小顺序排成一个单向链表
    • 各个存放用户记录的页也是根据页中用户记录的主键大小顺序排成一个双向链表
    • 存放目录项记录的页分为不同的层次,在同一层次中的页也是根据页中目录项记录的主键大小顺序排成一个双向链表
  2. B+树的叶子节点存储的是完整的用户记录。

    所谓完整的用户记录,就是指这个记录中存储了所有列的值(包括隐藏列)。

我们把具有这两种特性的B+树称为聚簇索引,所有完整的用户记录都存放在这个聚簇索引的叶子节点处。这种聚簇索引并不需要我们在MySQL语句中显式的使用INDEX语句去创建,InnoDB存储引擎会自动的为我们创建聚簇索引。

在我们往数据表中添加数据时,InnoDB会检查该表是否有用户创建的主键,没有主键会用唯一的非空索引作为聚簇索引,如果也没有唯一非空索引就会生成一个隐藏的主键(RowId)作为聚簇索引。

优点:

缺点:

限制:

MySQL索引更详细内容

上一篇 下一篇

猜你喜欢

热点阅读