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

news/2024/12/14 15:51:21/

前言

仅做学习记录,侵删

一、什么是索引

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

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

其本质是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+树由于其高效的范围查询性能,更适合用于文件系统的索引和数据库索引。


http://www.ppmy.cn/news/1555054.html

相关文章

2024年12月10日Github流行趋势

项目名称:astral-sh / uv 项目维护者:charliermarsh zanieb konstin renovate BurntSushi项目介绍:一个极快的Python包和项目管理器,使用Rust编写。项目star数:30,855项目fork数:839 项目名称:…

每天40分玩转Django:简介和环境搭建

Django简介和环境搭建 一、课程概述 学习项目具体内容预计用时Django概念Django框架介绍、MVC/MTV模式、Django特点60分钟环境搭建Python安装、pip配置、Django安装、IDE选择45分钟创建项目项目结构、基本配置、运行测试75分钟实战练习创建个人博客项目框架60分钟 二、Djang…

查询三网话费余额接口,移动话费余额接口、电信话费余额接口、联通话费余额的接口+html前端查询UI界面

PHP是直接请求的接口&#xff0c;HTML代码也是直接请求的接口。如果HTML想上线运行&#xff0c;还是需要做下安全的。 下边是PHP代码 <?php // 定义API接口地址和参数 $apiUrl "https://api.taolale.com/api/Inquiry_Phone_Charges/get"; //API文档地址&…

tklog0.2.8—Rust高性能日志库

tklog是rust高性能结构化日志库&#xff0c;支持同步日志&#xff0c;异步日志&#xff0c;支持自定义日志的输出格式&#xff0c;支持按时间&#xff0c;按文件大小分割日志文件&#xff0c;支持日志文件压缩备份&#xff0c;支持官方日志库标准API&#xff0c;支持mod独立参数…

网络原理初识一>网络基本的概念, 网络如何转发

目录&#xff1a; 一.网络基本的概念&#xff1a; 二. 封装和分用 (网络转发)&#xff1a; 一.网络基本的概念&#xff1a; 1..局域网 (LAN)&#xff1a; 局域网&#xff0c;即 Local Area Network&#xff0c;简称LAN。 Local 即标识了局域网是本地&#xff0c;局部组建的…

Golang学习笔记_08——For循环

Golang学习笔记_05——延迟调用 Golang学习笔记_06——变量和常量 Golang学习笔记_07——基本类型 文章目录 For循环1. 基本形式2. 省略形式3. While循环4. 无限循环5. 使用 range 进行迭代 源码 For循环 在Go语言中&#xff0c;for 循环是唯一的一种循环结构&#xff0c;它非…

chattts生成的音频与字幕修改完善,每段字幕对应不同颜色的视频,准备下一步插入视频。

上一节中&#xff0c;实现了先生成一个固定背景的与音频长度一致的视频&#xff0c;然后插入字幕。再合并成一个视频的方法。 但是&#xff1a;这样有点单了&#xff0c;所以&#xff1a; 1.根据字幕的长度先生成视频片断 2.在片段上加上字幕。 3.合并所有片断&#xff0c;…

.NET(C#) 如何配置用户首选项及保存用户设置

最近开发软件&#xff0c;需要将用户设置保存下来以便下次打开后再用&#xff0c;看了半天原来.NET框架自带setting功能。记录如下&#xff1a; 一&#xff0c;“设置” 页面 使用项目设计器的“设置”页指定项目的应用程序设置。 通过应用程序设置&#xff0c;能够为应用程序…