* GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源。
索引介绍
索引是一种特殊的数据库结构,被设计用来快速查询数据库表中的特定记录。索引有多种类型,就像字典有拼音查找和偏旁查找一样都是为了提高检索效率。MySQL中最常见的索引类型有
B+树索引
和哈希索引
,下面来简单介绍一下这两种索引类型有哪些差别和优劣。
B+树索引
B+树索引是一种多路径的平衡搜索树,具有如下特点:
1.非叶子节点不保存数据,只保存索引值 2.叶子节点保存所有的索引值和数据 3.同级节点通过指针自小而大顺序链接 4.节点内的数据也是自小而大顺序存放 5.叶子节点拥有父节点的所有信息
结构如下图:

优点
由于数据顺序存放,所以无论是区间还是顺序扫描都更快。 非叶子节点不存储数据,因此几乎都能放在内存中,搜索效率更高 单节点中可存储的数据更多,平均扫描I/O请求树更少 平均查询效率稳定(每次查询都从根结点到叶子结点,查询路径长度相同)
缺点
新增数据不是按顺序递增时,索引树需要重新排列,容易造成碎片和页分裂情况。
哈希索引
哈希索引采用一定的哈希算法,把键值换算成新的哈希值,检索时不需要类似B+树那样从根节点到叶子节点逐级查找,只需一次哈希算法即可立刻定位到相应的位置,速度非常快,具有如下特点:
1.哈希索引建立在哈希表的基础上 2.对于每个值,需要先计算出对应的哈希码(Hash Code),不同值的哈希码唯一 3.把哈希码保存在哈希表中,同时哈希表也保存指向对应每行记录的指针
结构如下图:

优点
大量唯一等值查询时,哈希索引效率通常更高。
缺点
哈希索引对于范围查询和模糊匹配查询显得无能为力。 哈希索引不支持排序操作,对于多列联合索引的最左匹配规则也不支持。 哈希索引不支持前缀索引,因为哈希索引始终是使用索引列的全部内容来计算哈希值。 如果存在哈希冲突的情况,也就是不同的索引列有着相同的哈希值,这时候需要遍历链表中所有的行指针进行逐行比对,直到找到所有满足条件的行,效率较低。
Enjoy GreatSQL :)
《深入浅出MGR》视频课程
戳此小程序即可直达B站
https://www.bilibili.com/medialist/play/1363850082?business=space_collection&business_id=343928&desc=0
文章推荐:
想看更多技术好文,点个“在看”吧!
文章转载自老叶茶馆,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。
评论
相关阅读
【MySQL 30周年庆】MySQL 8.0 OCP考试限时免费!教你免费领考券
墨天轮小教习
3292次阅读
2025-04-25 18:53:11
MySQL 30 周年庆!MySQL 8.4 认证免费考!这次是认真的。。。
严少安
907次阅读
2025-04-25 15:30:58
【活动】分享你的压箱底干货文档,三篇解锁进阶奖励!
墨天轮编辑部
535次阅读
2025-04-17 17:02:24
MySQL 9.3 正式 GA,我却大失所望,新特性亮点与隐忧并存?
JiekeXu
456次阅读
2025-04-15 23:49:58
3月“墨力原创作者计划”获奖名单公布
墨天轮编辑部
383次阅读
2025-04-15 14:48:05
MySQL 8.0 OCP 1Z0-908 考试解析指南(二)
JiekeXu
351次阅读
2025-04-30 17:37:37
记录MySQL数据库的一些奇怪的迁移需求!
陈举超
303次阅读
2025-04-15 15:27:53
SQL优化 - explain查看SQL执行计划(下)
金同学
297次阅读
2025-05-06 14:40:00
MySQL 30 周年庆!MySQL 8.4 认证免费考!这次是认真的。。。
数据库运维之道
293次阅读
2025-04-28 11:01:25
MySQL 8.0 OCP 1Z0-908 考试题解析指南
青年数据库学习互助会
291次阅读
2025-04-30 12:17:54