当前位置:网站首页 > SQL数据库编程 > 正文

mysql主键索引和聚集索引(mysql主键索引和聚集索引的区别)



数据库的索引从不同的角度可以划分成不同的类型,聚簇索引便是其中一种。

聚簇索引英文是 Clustered Index,有时候小伙伴们可能也会看到有人将之称为聚集索引等,与之相对的是非聚簇索引或者二级索引。

聚簇索引并不是一种单独的索引类型,而是一种数据的存储方式。在 MySQL 的 InnoDB 存储引擎中,所谓的聚簇索引实际上就是在同一个 B+Tree 中保存了索引和数据行:此时,数据放在叶子结点中,聚簇聚簇,意思就是说数据行和对应的键值紧凑的存在一起。

假设我有如下数据:

那么它的聚簇索引大概就是这个样子:

那么大家可以看到,叶子上既有主键值(索引)又有数据行,节点上则只有主键值(索引)。

小伙伴们想想,MySQL 表中的数据在磁盘中只可能保存一份,不可能保存两份,所以,在一个表中,聚簇索引只可能有一个,不可能有多个。

有的小伙伴搞不清楚这两者之间的关系,甚至将两者划等号,这是一个巨大的误区。

在有的数据库中,支持开发者自由的选择使用哪一个索引作为聚簇索引,但是 MySQL 中是不支持这个特性的。

在 MySQL 中,如果表本身就有设置主键,那么主键就是聚簇索引;如果表本身没有设置主键,则会选择表中的一个唯一且非空的索引来作为聚簇索引;如果表中连唯一非空的索引都没有,那么就会自动选择表中的隐式主键来作为聚簇索引。关于 MySQL 中表的隐式主键,松哥会在将来的文章中和大家介绍。

不过一般来说,还是建议大家自己来为表设置主键,因为隐式主键是自增的,自增的都会存在一个问题:在自增值上会存在非常高的锁竞争问题,主键的上界会称为热点数据,因为所有的插入操作都要主键自增,又不能重复,所以会发生锁竞争进而导致性能降低。

根据上面的介绍,我们可以总结出 MySQL 中聚簇索引和主键索引的关系如下:

先来说优点:

这些就是聚簇索引一些常见的优点,我们在日常的表设计中,其实应该充分利用好这些优点。

再来看看缺点:

看了上面的介绍,相信小伙伴已经了解了,在使用聚簇索引的时候,主键最好不要使用 UUID 这种随机字符串,使用 UUID 随机字符串至少存在两方面的问题:

所以相对来说,主键自增会优于 UUID。那么主键自增就是最完美的方案了吗?很多小伙伴可能也听说过一句话:没有银弹!所以,主键自增其实也有问题,具体什么问题,我们下篇文章继续。

到此这篇mysql主键索引和聚集索引(mysql主键索引和聚集索引的区别)的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!

版权声明


相关文章:

  • sql窗口函数是什么意思(sql窗口函数有哪些)2026-02-12 14:45:07
  • 数据库入门基础知识(sql数据库入门基础知识)2026-02-12 14:45:07
  • sql循环语句(sql循环语句的几种写法)2026-02-12 14:45:07
  • .sql文件的作用(数据库.sql文件)2026-02-12 14:45:07
  • mysql的主键自增(mysql主键自增原理)2026-02-12 14:45:07
  • mysql主键查询快还是索引查询快(mysql主键查询快还是索引查询快)2026-02-12 14:45:07
  • pymssql连接数据库 报错(使用pymssql连接数据库报错)2026-02-12 14:45:07
  • mysql查看主键索引(mysql主键索引重复创建哪个会生效)2026-02-12 14:45:07
  • sql循环语句怎么写出来(sql里循环怎么用)2026-02-12 14:45:07
  • orcale和mysql的区别(oracle 和mysql的区别)2026-02-12 14:45:07
  • 全屏图片