news 2026/6/15 15:03:47

一文讲透索引数据结构——B-Tree / B+Tree / Hash 的特点及对比

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
一文讲透索引数据结构——B-Tree / B+Tree / Hash 的特点及对比

B-Tree

二叉树的缺点:

B-Tree(多路平衡查找树)

B+Tree

01-标准的B+Tree结构

演变过程:分裂时中间元素向上分裂,同时该中间元素会停留在分裂后的右子树中,这样才能保证所有的数据会出现在叶子结点

相对于B-Tree区别:

  • 所有的数据都会出现在叶子节点
  • 叶子节点形成一个单向链表

02-MySQL索引中的B+Tree结构

MySQL索引数据结构对经典的B+Tree进行了优化。在原B+Tree的基础上,增加一个指向相邻叶子节点的链表指针,就形成了带有顺序指针的B+Tree,提高区间访问的性能

Hash

哈希索引就是采用一定的hash算法,将键值换算成新的hash值,映射到对应的槽位上,然后存储在hash表中;

如果两个(或多个)键值,映射到一个相同的槽位上,他们就产生了hash冲突(也称为hash碰撞),可以通过链表来解决

Hash索引特点:

  • Hash索引只能用于对等比较(=,in),不支持范围查询(between,>,< ,...)
  • 无法利用索引完成排序操作(Hash运算出来的结果是无序的)
  • 查询效率高,通常(不存在hash冲突的情况)只需要一次检索就可以了,效率通常要高于B+tree索引

存储引擎支持:

在MySQL中,支持hash索引的是Memory存储引擎

InnoDB中具有自适应hash功能,hash索引是InnoDB存储引擎根据B+Tree索引在指定条件下自动构建的

为什么InnoDB存储引擎选择使用B+tree索引结构?

  • 相对于二叉树层级更少,搜索效率高

对于B-Tree,无论是叶子节点还是非叶子节点,都会保存数据,这样导致一页中存储的键值减少,指针跟着减少,在保存相同数据量的情况下只能增加树的高度,导致性能降低

  • 如果采用B+Tree索引结构,不管查找哪一个数据都要到叶子结点当中才能找到对应的数据,搜索效率更稳定;
  • 在B+Tree索引结构中,叶子结点形成了一个双向链表,便于范围搜索和排序

  • 相对Hash索引,B+tree支持范围匹配排序操作

这个可以作为面试题好好理解下

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 3:21:19

多模态模型实践 - 图文跨模态检索实战教程

目录 摘要 1 引言&#xff1a;多模态检索的时代价值与挑战 2 技术原理&#xff1a;跨模态检索的架构设计 2.1 核心架构设计理念 2.2 CLIP模型原理深度解析 2.3 多模态检索系统性能分析 3 实战部分&#xff1a;完整可运行代码示例 3.1 环境配置与依赖管理 3.2 数据预处…

作者头像 李华
网站建设 2026/6/12 3:48:49

基于Java+SSM的高校学生宿舍管理系统(源代码+文档+PPT+调试+讲解)

课题摘要基于 JavaSSM&#xff08;SpringSpringMVCMyBatis&#xff09;架构的高校学生宿舍管理系统&#xff0c;直击 “传统宿舍管理依赖人工记录、信息查询繁琐、资源调配低效、学生诉求响应慢” 的核心痛点&#xff0c;依托 Java 的稳定性与 SSM 框架的分层架构优势&#xff…

作者头像 李华
网站建设 2026/6/15 13:34:16

如何实现完全离线的AI文档生成:DeepWiki-Open本地部署终极指南

如何实现完全离线的AI文档生成&#xff1a;DeepWiki-Open本地部署终极指南 【免费下载链接】deepwiki-open Open Source DeepWiki: AI-Powered Wiki Generator for GitHub Repositories 项目地址: https://gitcode.com/gh_mirrors/de/deepwiki-open 你是否担心将公司代码…

作者头像 李华
网站建设 2026/6/14 18:27:43

AI助力开发:5分钟打造你的谷歌浏览器视频下载插件

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个谷歌浏览器扩展程序&#xff0c;能够下载网页中的视频内容。主要功能包括&#xff1a;1)检测当前页面中的视频元素 2)提供下载按钮 3)支持多种视频格式下载 4)可设置下载质…

作者头像 李华
网站建设 2026/6/15 13:11:14

Macyy会员系统AI自动化开发实战

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个Macyy会员管理系统&#xff0c;需要包含以下功能&#xff1a;1.会员注册/登录 2.积分累计与兑换 3.电子优惠券发放 4.购买历史记录 5.个性化推荐。后端使用Python Flask框架…

作者头像 李华
网站建设 2026/6/15 13:09:43

Symfony Translation组件版本升级实战:从依赖管理到多语言应用现代化

Symfony Translation组件版本升级实战&#xff1a;从依赖管理到多语言应用现代化 【免费下载链接】translation symfony/translation: 是一个用于 PHP 的翻译库&#xff0c;支持多种消息源和翻译格式&#xff0c;可以用于构建多语言的 Web 应用程序和 API。 项目地址: https:…

作者头像 李华