【数据结构】数据库索引(B树,B+树)简介

前言

仅做学习记录,侵删

一、什么是索引

索引是数据库表中的字段的索引,所谓的索引就是在表的字段上添加的,每个字段都可以添加索引来提高查找效率,也可以多个字段联合添加一个索引。

参考字典的实现,索引相当于字典的目录,通过目录缩小查找范围。

其本质是B 树, B+树

二、 什么是B树和B+树,二者的区别是什么?

B树(B-Tree)

B树是一种平衡的多路搜索树,它具有以下特点:

  1. 节点结构:B树的每个节点可以有多个子节点,通常每个节点包含多个键值和多个指针,这些指针指向子节点。
  2. 平衡性:B树是平衡的,这意味着从根节点到每个叶子节点的路径长度相同。
  3. 键值分布:B树中的键值是有序的,并且每个节点中的键值会分布在所有子节点中。
  4. 搜索效率:由于B树是平衡的,所以搜索效率很高,时间复杂度为O(log n)。
  5. 插入和删除:在B树中插入和删除节点时,可能需要进行节点的分裂和合并操作以保持树的平衡。

B+树(B+-Tree)

B+树是B树的一种变体,它具有以下特点:

  1. 节点结构:B+树的内部节点不存储数据,只存储键值和子节点指针。数据只存储在叶子节点中。
  2. 非叶子节点:B+树的非叶子节点只存储键值和指向子节点的指针,不存储实际的数据。
  3. 叶子节点链表:B+树的所有叶子节点是相互链接的,形成一个链表,这使得范围查询更加高效。
  4. 查询效率:由于数据都存储在叶子节点,并且叶子节点之间是链表连接的,所以B+树在进行范围查询时非常高效。
  5. 空间利用:B+树的非叶子节点不存储数据,因此可以存储更多的键值,提高了空间利用率。
  6. 插入和删除:在B+树中插入和删除节点时,同样可能需要进行节点的分裂和合并操作。

B树和B+树的区别

  1. 数据存储位置:B树的节点可以存储数据,而B+树的数据只存储在叶子节点。
  2. 查询效率:B+树由于叶子节点之间的链表结构,使得范围查询更加高效。
  3. 空间利用率:B+树的非叶子节点不存储数据,因此可以存储更多的键值,提高了空间利用率。
  4. 插入和删除:B+树在插入和删除时,由于叶子节点是链表结构,操作可能更加简单。
  5. 适用场景:B树适用于需要同时进行点查询和范围查询的场景,而B+树由于其高效的范围查询性能,更适合用于文件系统的索引和数据库索引。
相关推荐
-SGlow-2 小时前
MySQL相关概念和易错知识点(2)(表结构的操作、数据类型、约束)
linux·运维·服务器·数据库·mysql
爱装代码的小瓶子2 小时前
数据结构之队列(C语言)
c语言·开发语言·数据结构
明月5663 小时前
Oracle 误删数据恢复
数据库·oracle
水瓶_bxt5 小时前
Centos安装HAProxy搭建Mysql高可用集群负载均衡
mysql·centos·负载均衡
♡喜欢做梦5 小时前
【MySQL】深入浅出事务:保证数据一致性的核心武器
数据库·mysql
遇见你的雩风5 小时前
MySQL的认识与基本操作
数据库·mysql
dblens 数据库管理和开发工具5 小时前
MySQL新增字段DDL:锁表全解析、避坑指南与实战案例
数据库·mysql·dblens·dblens mysql·数据库连接管理
weixin_419658315 小时前
MySQL的基础操作
数据库·mysql
aramae5 小时前
大话数据结构之<队列>
c语言·开发语言·数据结构·算法
不辉放弃6 小时前
ZooKeeper 是什么?
数据库·大数据开发