MySQL-聚簇索引、二级索引与联合索引的概念

聚簇索引,二级索引和联合索引

聚簇索引

索引按照物理实现方式,那么索引可以分为俩种:聚簇索引和非聚簇索引。我们也称聚簇索引为二级索引或者辅助索引

聚簇索引并不是一种单独的索引类型,而是一种数据的存储方式(所有的用户记录都存储在了叶子结点)也就是:索引即数据,数据及索引。

特点:

  • 使用记录主键值的大小进行记录和页的排序,这包括三个方面的含义:
    • 页内的记录是按照主键的大小排序成为一个单项链表
    • 各个存放用户记录的页也是根据页中的用户记录的主键大小排序成一个双向链表
    • 存放目录香记录的页分为不同的层次,在同一层中的页也是根据页中的目录项记录的主键大小排列成一个双向链表

优点:

  • 访问数据更快,因为数据索引和数据存放在同一个b+树中间
  • 聚簇索引对于主键的排序查找和范围查找速度非常快
  • 按照聚簇索引排列顺序查找,查询显示到一定的范围数据的时候,由于数据都是紧密相连的,数据库不需要从多个数据块中提取数据库,所以节省了大量的IO操作

缺点:

  • 插入速度严重依赖于插入顺序:按照主键的顺序插入是最快的插入方式,如果不按照这个顺序那么将会发生页分裂,严重的影响性能,因此对于InnoDB表 我们一般会定义一个自增的主键
  • 更新主键的代价很高,因为将会导致更新的行移动,因此,对于InnoDB表,我们一般定义主键为不可以更新的
  • 二级索引访问需要俩次索引查找,第一次找到主键值,第二次根据主键值找到行数据

限制:

  • 对于MySql数据库InnoDB支持聚簇索引,MyISAM不支持聚簇索引
  • 由于数据物理储存方式只能有一种,所以每一个Mysql表中只能有一个聚簇索引,一般情况下就是该表的主键
  • 如果没有定义主键,InnoDB 会选择非空唯一索引代替
  • 那么基于这种情况,InnoDB的主键 一般会选择有顺序的id,而不是去使用无序的id 、比如:UUID,MD5,HASH等,因为使用这一些无法保证这些数据是否为按照顺序自增的。

二级索引

二级索引树的叶子节点存储的是主键而不是数据。也就是说,在找到索引后,得到对应的主键,再回到一级索引中找主键对应的数据记录

概念: 回表

我们一般只能查到记录的主键值,所以我们要查找到c2列的值查找完整记录用户的话,仍然需要到聚簇索引中在查一遍,那么我们称这个过程为回表

一般而言一个InnoDB中只有一个主键索引,有多个二级索引

小结:聚簇索引与非聚簇索引的原理不同的,在使用上也有一些区别:

  1. 聚簇索引的叶子结点储存的就是我们的数据结记录,非聚簇索引的叶子结点储存的是数据位置,非聚簇索引不会影响数据表的物理储存数据。
  2. 使用聚簇索引的时候,数据的查询效率高,但是如果对数据进行插入,删除,更新等操作,效率会比非聚簇索引低。

联合索引

我们也可以同时以多个列的大小作为排序规则,也就是同时为多个列建立索引,这里包含了俩层含义

  • 先将各个记录和页按照指定
  • 在记录相同的情况下,然后在树结构中不包含列进行排序
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

敏姐儿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值