千家信息网

InnoDB索引实现

发表于:2025-11-08 作者:千家信息网编辑
千家信息网最后更新 2025年11月08日,对于InnoDB存储引擎的表,记录默认会按一定顺序保存,如果有明确定义的主键,则按照主键顺序保存。如果没有主键,但是有唯一索引,就按照唯一索引的顺序保存。如果既没有主键也没有唯一索引,表中会自动生成一
千家信息网最后更新 2025年11月08日InnoDB索引实现

对于InnoDB存储引擎的表,记录默认会按一定顺序保存,如果有明确定义的主键,则按照主键顺序保存。如果没有主键,但是有唯一索引,就按照唯一索引的顺序保存。如果既没有主键也没有唯一索引,表中会自动生成一个内部列,按照这个列的顺序保存。按照主键或内部列的访问是最快的,索引InnoDB表尽量自己指定主键,当表中同时有几个列都是唯一的,都可以作为主键的时候,要选择最常作为访问条件的列作为主键,提高查询效率。另外,InnoDB表的普通索引都会保存主键的键值,这样通过对索引加锁就可以实现行级锁。

可以说数据库必须有索引,没有索引则检索过程变成了顺序查找,O(n)的时间复杂度几乎是不能忍受的。我们非常容易想象出一个只有单关键字组成的表如何使用B+树进行索引,只要将关键字存储到树的节点即可。当数据库一条记录里包含多个字段时,一棵B+树就只能存储主键,如果检索的是非主键字段,则主键索引失去作用,又变成顺序查找了。这时应该在第二个要检索的列上建立第二套索引。 这个索引由独立的B+树来组织。有两种常见的方法可以解决多个B+树访问同一套表数据的问题,一种叫做聚簇索引(clustered index ),一种叫做非聚簇索引(secondary index)。这两个名字虽然都叫做索引,但这并不是一种单独的索引类型,而是一种数据存储方式。对于聚簇索引存储来说,行数据和主键B+树存储在一起,辅助键B+树只存储辅助键和主键,主键和非主键B+树几乎是两种类型的树。对于非聚簇索引存储来说,主键B+树在叶子节点存储指向真正数据行的指针,而非主键。

InnoDB使用的是聚簇索引,将主键组织到一棵B+树中,而行数据就储存在叶子节点上,若使用"where id = 14"这样的条件查找主键,则按照B+树的检索算法即可查找到对应的叶节点,之后获得行数据。若对Name列进行条件搜索,则需要两个步骤:第一步在辅助索引B+树中检索Name,到达其叶子节点获取对应的主键。第二步使用主键在主索引B+树种再执行一次B+树检索操作,最终到达叶子节点即可获取整行数据。

MyISM使用的是非聚簇索引,非聚簇索引的两棵B+树看上去没什么不同,节点的结构完全一致只是存储的内容不同而已,主键索引B+树的节点存储了主键,辅助键索引B+树存储了辅助键。表数据存储在独立的地方,这两颗B+树的叶子节点都使用一个地址指向真正的表数据,对于表数据来说,这两个键没有任何差别。由于索引树是独立的,通过辅助键检索无需访问主键的索引树。

为了更形象说明这两种索引的区别,我们假想一个表如下图存储了4行数据。其中Id作为主索引,Name作为辅助索引。图示清晰的显示了聚簇索引和非聚簇索引的差异。

聚簇索引优点:

1 查询速度更快:由于行数据和叶子节点存储在一起,这样主键和行数据是一起被载入内存的,找到叶子节点就可以立刻将行数据返回了,如果按照主键Id来组织数据,获得数据更快。

2 减少索引维护:辅助索引使用主键作为"指针" 而不是使用地址值作为指针的好处是,减少了当出现行移动或者数据页分裂时辅助索引的维护工作,使用主键值当作指针会让辅助索引占用更多的空间,换来的好处是InnoDB在移动行时无须更新辅助索引中的这个"指针"。也就是说行的位置(实现中通过16KPage来定位,后面会涉及)会随着数据库里数据的修改而发生变化(前面的B+树节点分裂以及Page的分裂),使用聚簇索引就可以保证不管这个主键B+树的节点如何变化,辅助索引树都不受影响。

InnoDB行锁的实现:

InnoDB的行锁是加在索引上的,实现过程如下:

1.按辅助索引检索:行锁加在辅助索引对应的列,并根据主键项找到主键索引加锁。

如上图,按name字段检索name='Ellision'Ellision索引列会加锁,并在主键索引项14 加锁。这样当其他事务就无法访问name='Ellision'列,也无法根据其他数据项访问相应的数据列。


索引 数据 存储 辅助 节点 检索 叶子 顺序 指针 两个 字段 条件 独立 不同 关键 关键字 地址 多个 好处 指向 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 数据库 辅助工具 如何更改数据库的所有者 数据库原理读后感5000 文件管理服务器错误 超微服务器花屏 网络安全哪里的课程好 扫黄打黑网络安全手抄报 广州卓越互联网科技公司 嵩县软件开发 帝国cms修改数据库权限 方法支持事物数据库不支持事物 网络安全的涉及范围 武汉大学网络安全学院排名 网络技术与新媒体课程 el-tree获取数据库 造价项目管理软件开发 黄浦区软件开发销售电话 软件技术和计算机网络技术专业 不缺暖阳网络技术有限公司 智能汽车网络安全准则 河南天岳人和网络技术有限公司 网络安全行稳致远 石家庄数据库培训多少钱 广州同林网络技术有限公司 软件开发与应用什么专业 我市举行网络安全宣传周启动 二年级网络安全手抄报文字素材 高级数据库技术课后题大难 谷歌打开网页提示服务器错误 路由器搭建服务器如何防护
0