聚簇索引和非聚簇索引

先说区别

1.聚簇索引文件中的每个搜索码值都对应一个索引值

2.非聚簇索引文件只为索引码的某些值建立索引项

是不是看起来懵懵的

简单直白点就是,聚簇索引的索引码直接对应数据值,非聚簇索引的索引码对应的是数据的地址,就是说聚簇索引的索引和数据是放在同一个文件里,而非聚簇索引就是索引和数据分开文件存放。

举个例子

我们常用的数据库mysql里的索引存储引擎InnoDB和MyISAM

1.InnoDB就是聚簇索引的例子

2.MyISAM就是非聚簇索引的例子

那说一下InnoDB和MyISAM

InnoDB

1.若一个主键被定义,该主键则作为密集索引(聚簇索引)

2.若没有主键被定义,该表的第一个唯一非空索引则作为密集索引(这个很好理解,反正我要找一个作为密集索引)

3.若不满足以上条件,InnoDB内部会生成一个隐藏主键(如果这个表真的一个索引都没有,那么就隐式生成一个主键(密集索引))

4.非主键索引存储相关键为和其对应的主键值,包含两次查找。

这里密集索引和稀疏索引都一样的,辅助索引会先通过索引检索到主键索引,然后主键索引检索数据值 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值