MySQL中聚簇索引和非聚簇索引的对比:

文章详细阐述了聚簇索引和非聚簇索引的概念,特点及使用情况。聚簇索引基于主键排序,叶子节点存储完整记录,InnoDB存储引擎支持而MyISAM不支持。非聚簇索引的叶子节点只含主键值,查找需回表。每个表只有一个聚簇索引,若无主键,系统会自动生成。
摘要由CSDN通过智能技术生成

一、聚簇索引:

1、定义:

聚簇索引也叫聚集索引,它实际上并不是一种单独的索引类型,而是一种数据存储方式,聚簇索引的叶子节点保存了一行记录的所有列信息。也就是说,聚簇索引的叶子节点中,包含了一个完整的记录行。

2、特点:

①、使用记录主键值的大小进行记录和页的排序,使用记录主键值的大小进行记录和页的排序。

②、数据页内的记录是按照主键的大小顺序排成一个单向链表

③、各个存放记录行的页也是根据页中用户记录的主键大小顺序排成一个双向链表

④、存放目录项记录的页分为不同的层次,在同一层次中的页也是根据页中目录项记录的主键

大小顺序排成一个 双向链表
⑤、 B+ 树的 叶子节点 存储的是完整的用户记录。这个 完整的用户记录,就是指这个记录中存储了所有列的值。
⑥、聚簇索引中数据行和索引结构存储在一起。
⑦、InnoDB存储引擎支持聚簇索引,MyISAM不支持。
⑧、每个MySQL表中只能有一个聚簇索引,由主键构成。
3、使用:

在InnoDB中,每张表必须有一个聚簇索引,默认情况下会根据主键建立。如果表中没有主键,InnoDB会选择一个合适的列作为聚簇索引,如果找不到合适的列,会使用一列隐藏的列DB_ROW_ID作为聚簇索引。

二、非聚簇索引:

1、定义:

非聚簇索引也叫辅助索引、普通索引,它的叶子节点只包含主键值,通过非聚簇索引查找记录要先找到主键,然后通过主键再到聚簇索引中找到对应的记录行,这个过程被称为回表。

2、举例:

假如现在有一个包含了用户姓名的数据表,假设主键是用户的ID,

而一个非聚簇索引(以name为索引)的结构是:

除了name字段本身之外,在该节点的叶子节点中,仅包含当前记录的主键ID,而不包含完整记录的信息。需要通过name字段查找到相应的主键字段ID,再通过字段ID到聚簇索引中进行回表查询才能获取完整的记录行。

3:使用:

使用非聚簇索引需要进行两次索引的查找, 第一次找到主键值,第二次根据主键值进行回表然后找到相应记录行。
声明:
个人学习总结,如有问题,欢迎指出!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值