mysql索引

索引

概念:索引是帮助mysql高效查找数据且排序好的一种数据结构

mysql存储索引使用2种方式:

1,hash:hash方式等值查询效率很高,但是范围查询效率退化成全表扫描。

2,B+树(外排序的一种实现)

​ mysql 一般使用 B+树,建立索引结构,3层即可满足千万级别数据索引的存储,大大减少了磁盘io的次数。同时b+树叶子结点顺序存储了所有索引元素,相当于一个顺序表,根据树结构查找到对应的元素上下界后,可以很好的支持范围查找。

mysql 支持的B+树:

  • 非叶子节点不存储data,只存储索引,所以每个树节点可以存储更多的索引。(树的一个节点一般为16k)
  • 叶子节点不用存储指针
  • 叶子节点提供了顺序访问的指针,可提高区间访问的性能,更好的支持了范围查询

在这里插入图片描述

mysql常用引擎:

mylSAM存储引擎:其索引实现为:

在这里插入图片描述

data种存放的是每一列数据的地址信息。

InnoDB索引实现(聚集索引):

  • 表数据文件本身就是按照B+tree组织的一个索引结构文件

  • 聚集索引-节点包含了完整的数据记录

  • 问题1:为什么InnoDB表必须有主键?并且推荐使用整形的自增主键?

    答:是因为这样可以使插入一条数据永远为最后一条数据(如果使用的是varchar类型的作为主键,则新插入一条数据,有可能是在中间插入,可能会增加分裂次数,增加维护开销),在叶子链表的最后,减少b+树分裂的次数,这样就降低了维护代价

  • 问题2:为什么非主键索引结构的叶子节点存储的是主键值?

    答:为了一致性(个人理解:防止当增加一条数据时,需要在多个索引结构中进行多数据的添加)。节省存储空间。

:防止当增加一条数据时,需要在多个索引结构中进行多数据的添加)。节省存储空间。

在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值