当前位置: 首页 > news >正文

InnoDB为什么使用B+Tree

分析&回答

1.B+ Tree的层数较少

B类树的一个很鲜明的特点就是数的层数比较少,而每层的节点非常多,树的每个叶子节点到根节点的距离都是相同的;

2.   减少磁盘IO;

树的每一个节点都是一个数据也,这样每个节点只需要一次IO就可以全部读取,这样的结构保证了查询数据时能尽量的少进行磁盘IO,同时保证IO的稳定性;

3.B+ Tree在内存中能存储更多的索引数据;

B+ Tree和B Tree不同,B+Tree中,只能将数据存储在叶子节点中,内部节点只包含指向下一节点的指针,而B Tree可以将数据存储在内部的叶节点中;

因此 B+ Tree的关键又是在于中间节点不包含数据,因此B+Tree的大小远小于B Tree,并且可以将更多的数据存储到磁盘中(反之,存储到叶节点的索引键值也就更多)

4.适合范围查询:

另外B+ Tree的每一个叶子节点包含了到相邻的节点的链接(维护了一个单向链表,将叶子节点连接起来),这样可以快速地进行范围比遍历;

喵呜面试助手:一站式解决面试问题,你可以搜索微信小程序 [喵呜面试助手] 或关注 [喵呜刷题] -> 面试助手 免费刷题。如有好的面试知识或技巧期待您的共享!

http://www.lryc.cn/news/160001.html

相关文章:

  • 【Spring Bean的生命周期实现方式】
  • 腾讯云PK阿里云2核2G云服务器租用价格表
  • 【美团3.18校招真题2】
  • 一文带你快速入门『YOLOv8』
  • # 将PCL点云转换为Eigen向量进行运算
  • elmentui表单重置及出现的问题
  • 游戏平台加盟该怎么做?需要准备什么?
  • selenium中定位shadow-root,以及获取shadow-root内部的数据
  • OpenCV(三十二):轮廓检测
  • 接口自动化测试做线上巡检,如何避免数据污染
  • C++ 指针
  • SpringBoot集成kubernetes-client升级k8s后初始化失败问题
  • MySQL 学习笔记
  • Docker 的常用命令
  • 嵌入式-电子电路四个基本定律
  • 【linux命令讲解大全】083.Linux 常用命令ispell , spell , atrm, chattr
  • JAVA实现SAP接口
  • 华南理工大学811信号与系统考研分数线,招生人数,报考统计,考情分析,就业,真题,大纲,参考书,华工811
  • Android 字符串 占位符
  • vue页面添加水印(可用于H5,APP)
  • 下载git
  • MSYS2 如何切换镜像源(附带脚本自动修改)
  • 使用ICMP协议来判断UDP端口的存活状态
  • VUE for循环 默认选中第一条数据
  • 小程序代码管理
  • RK3568-GPIO控制
  • 2023开学礼《乡村振兴战略下传统村落文化旅游设计》许少辉八一新书南京师范大学图书馆
  • 【MySQL】什么是索引?如何选择索引类型?
  • 第16章 服务安全控制
  • 面试问题总结(1)