mysql中聚合索引和非聚合索引的区别

众所周知,索引是用来优化查询性能和降低修改性能的。

在讨论聚合和非聚合索引之前,必须先说下索引和数据(记录)的关系,下面大概是数据表的数据结构图,可能我说得不对,欢迎大佬指点

备注:此图来源:https://www.jianshu.com/p/5be9db088b97

简单说明下这张图的意思:

这张图表示的是一个B+数的数据结构,最下面一层的学术语叫“叶子节点”,第一层叫根节点,非第一层和最后一层为子节点。子节点和根节点存储主键(聚合索引),非聚合索引和行记录存储在叶子节点。

说完数据结构,应该也明白了聚合索引和非聚合索引的区别了吧,简单粗暴:能直接通过key值获取到数据的就是聚合索引,否则就是非聚合索引。如果表有主键(基本都有吧),则表的主键即为聚合索引,如果表没有主键,则mysql内部指定一个作为key

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值