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

什么是B+树

B+树是一种树数据结构。B+树索引是B+树在数据库中的一种实现,是最常见也是数据库中使用最为频繁的一种索引。

先来了解一下什么是索引?

一、索引

数据都是存储在硬盘上的,查询数据不可避免的需要进行IO操作。

索引是一种数据结构,又称之为“键(key)”,是存储引擎用于快速找到记录的一种数据结构。类似于书的目录,在查询数据的时候先找目录再找数据,而不是一页一页的翻。索引的存在提升来查询速度,降低来IO操作。

在一张表中可以有多个索引,但索引也不是越多越好。索引虽然可以帮助提升查询速度,但也是有缺点的:

1:当表中有大量数据存在的前提下,创建索引的速度会很慢

2:在索引创建完毕后,对表的查询性能会大幅度提升,但写的性能也会大幅度降低

因此索引不能随便的创建。

二、B+树

如图所示,这就是一个B+树,在非叶子结点上,存储的是一定范围内索引id对应的磁盘地址,叶子结点上存储的是具体的数据。

B+树之所以这么做的意义在于:树一个节点就是一个页,而数据库中页的大小是固定的,所以在页大小固定的前提下,能往一个页中放入更多的节点,相应的树的阶数(节点的子节点树)就会更大,那么树的高度就更矮,如此一来我们查找数据进行磁盘的IO次数有会再次减少,数据查询的效率也会更快。

B+树中各个页之间是通过双向链表连接的,叶子节点中的数据是通过单向链表连接的。

B+树叶子节点的关键字从小到大有序排列,左边节点的结尾数据都会保存右边节点的开始数据的指针,就构成了一个有序链表,在查询大小区间的数据时候更方便,速度更快。

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

相关文章:

  • 【Unity游戏破解】外挂原理分析
  • windows 关闭指定端口进程
  • 虚拟化系列教程:创建 KVM 虚机的几种方式
  • MacBook安装Golang Oracle数据库驱动程序
  • Elasticsearch 核心技术(七):IK 中文分词器的安装、使用、自定义字典
  • 【LeetCode】剑指 Offer(19)
  • 吐血整理,web自动化测试,POM模式搭建自动化测试框架(超级详细)
  • 【数据库原理复习】索引 视图 sql语句
  • 【HDFS】IPC重试
  • Revit导出CAD图纸操作及批量导出
  • 【批处理脚本】-3.4-goto命令详解
  • 超详细CentOS7 NAT模式(无图形化界面即最小安装)网络配置
  • 【可信平台】开证问题汇总--1.无采购入库记录,2.箱码无产出记录
  • RolePred: Open-Vocabulary Argument Role Prediction for Event Extraction 论文解读
  • 【数据结构】链表相关题目(简单版)
  • 通信原理 | FFT/STFT 你真的学会了吗?
  • Qt使用API实现鼠标点击操作
  • JavaWeb学习-Tomcat
  • 【蓝牙系列】蓝牙5.4到底更新了什么(2)
  • js中window自带的四舍五入toFixed方法中的坑以及解决办法
  • JeecgBoot 3.5.0 版本发布,开源的企业级低代码平台
  • 行测-判断推理-图形推理-样式规律-空间重构-四面体和八面体
  • HTML5新特性
  • TDengine Schemaless(无模式写入)常见问题的原因及故障排除
  • 【前端八股文】浏览器系列:浏览器渲染、前端路由、前端缓存(HTTP缓存)、缓存存储(HTTP缓存存储、本地存储)
  • SpiderFlow爬虫获取网页节点
  • “微服务架构:优点、缺点及实现方式“
  • c/c++实现crc码计算和校验
  • 漏洞分析丨cve20110104
  • 关于vue-router路径配置的问题(此文主要是记录三级路由的访问路径,以及安装、路由组件、路由重定向)