千家信息网

MySQL中MyISAM存储引擎的非聚簇索引分析

发表于:2024-10-01 作者:千家信息网编辑
千家信息网最后更新 2024年10月01日,本文小编为大家详细介绍"MySQL中MyISAM存储引擎的非聚簇索引分析",内容详细,步骤清晰,细节处理妥当,希望这篇"MySQL中MyISAM存储引擎的非聚簇索引分析"文章能帮助大家解决疑惑,下面跟
千家信息网最后更新 2024年10月01日MySQL中MyISAM存储引擎的非聚簇索引分析

本文小编为大家详细介绍"MySQL中MyISAM存储引擎的非聚簇索引分析",内容详细,步骤清晰,细节处理妥当,希望这篇"MySQL中MyISAM存储引擎的非聚簇索引分析"文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

在InnoDB中索引即数据,也就是聚簇索引的那颗B+树的叶子节点中已经包含了所有完整的用户记录。MyISAM的索引方案虽然也是使用树形结构,但是却将索引和数据分开存储,这种索引也叫非聚簇索引。

create table index_demo(        c1 int,        c2 int,        c3 char(1),        primary key(c1)) ROW_FORMAT=COMPACT;

将表中的记录按照记录的插入顺序单独存储在一个文件中,这个文件并不划分为若干个数据页,有多少记录就往这个文件中塞多少个记录,这样一来,我们就可以通过行号快速访问到一条记录。在表中使用MyISAM作为存储引擎时,它的记录在存储空间中的表示如图:

由于在插入数据时并没有刻意按照主键大小排序,所以我们不能再这些数据上使用二分法进行查找,使用MyISAM存储引擎的表会把索引信息单独存储在另外一个文件中,称为索引文件。MyISAM会为表的主键单独创建一个索引,只不过在索引的叶子节点中存储的不是完整的用户记录,而是主键值和行号的组合。也就是先通过索引找到对应的行号,再通过行号去找对应的记录。

在InnoDB存储引擎中,我们只需要根据主键值对聚簇索引进行一次查找就能找到对应的记录;在MyISAM存储引擎中,需要进行一次回表操作,这也意味着MyISAM中建立的索引相当于全部都是二级索引。

MyISAM会直接在索引叶子节点处存储该条记录在数据文件中的地址偏移量。由此可以看出MyISAM的回表操作时十分快速的,因为它是拿着地址偏移量直接到文件中取数据,而InnoDB是通过获取主键之后再去聚簇索引中找记录,虽然说不慢,但是也比不上直接用地址去访问。

如果有必要,我们也可以为其他列分别建立索引或者建立联合索引,其原理与InnoDB中索引差不多,只不过在叶子节点处存储的是相应的列+行号,这些索引页全部都是二级索引。

可以看到对于非聚簇索引,不管是以主键为排序规则还是以非主键为排序规则,它的结构都是相同的,即叶子节点存放的都是相应的列+行号。

读到这里,这篇"MySQL中MyISAM存储引擎的非聚簇索引分析"文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注行业资讯频道。

索引 存储 引擎 数据 文件 行号 叶子 节点 分析 文章 排序 也就是 内容 只不过 地址 用户 结构 规则 偏移 妥当 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 山西正前方网络技术有限公司 深圳软件开发网上培训班 软件开发与大学什么专业相关 粮粒图像数据库如何建立 公安信息网络安全工作思路 网络安全系统集成可以学到什么 邹平染厂管理软件开发 计算机网络安全比赛内容 数据库数据类型优化 什么是服务器配置与管理 mc服务器生成区域失败 如何在电脑上创建我的世界服务器 mc服务器无法连接 学软件开发需要掌握多少英语 惠普服务器机型怎么看 雅邦网络技术发展公司是做什么的 联想服务器raid管理器 java 连接远程数据库 北京达人游戏网络技术 备案提交网络安全员证书 戴尔服务器面板圆柱标 大专计算机网络技术月薪多少 hp服务器proc 高青管理erp软件开发公司 便宜的服务器cpu js连接数据库时 app图片如何保存数据库 魔兽世界臣人追猪者服务器平衡不 济南软件开发编程公司 平谷区定制软件开发操作
0