您的位置:首页 > 数据库 > MySQL

mysql之聚簇索引

2015-09-08 16:09 501 查看
聚簇索引不是一个独立的索引类型,而是一种数据存储的方式。InnoDB使用B-Tree来实现聚簇索引,并把索引和数据存放在同一结构中。在有聚簇索引的表中,索引和行是存放在同一个叶子节点(B-Tree)中的。"聚簇"表示索引值相邻的行的存储位置一般也是相邻的——一般来说是这样,但在某些情况下不是。一张表只能有一个聚簇索引,因为同一份数据不可能出现两个地方。

聚簇索引(Clustered Index)和非聚簇索引 (Non- Clustered Index)

最通俗的解释是:聚簇索引的顺序就是数据的物理存储顺序,而对非聚簇索引的索引顺序与数据物理排列顺序无关。举例来说,你翻到新华字典的汉字“爬”那一页就是P开头的部分,这就是物理存储顺序(聚簇索引);而不用你到目录,找到汉字“爬”所在的页码,然后根据页码找到这个字(非聚簇索引)。



图中展示了一个聚簇索引的示例,需要注意的是:只有叶子节点才包括了数据行的值,非叶子节点只存了索引字段。

在某些DB实现中,可以选择按照哪个索引做聚簇,但是MySQL的所有存储都不支持这样——InnoDB只能按照主键做聚簇。

如果表中没有定义主键,InnoDB会选择一个“非空且有唯一性约束“的索引来做聚簇,如果没有这样的索引,则会定义一个不可见的主键,并以这个主键来聚簇。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: