news 2026/4/15 16:52:27

索引的原理

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
索引的原理

一、索引的核心思想:空间换时间

  1. 代价:索引需要占用额外的存储空间,并且会在数据增删改时引入额外的维护开销。

  2. 收益:通过预先建立并维护一个更小的、针对性更强的数据结构,使得查询时能以远快于遍历全表的速度定位到目标数据。

二、索引的工作原理(类比字典)

以汉语字典为例:

  • 表数据:字典中所有的汉字及其解释(相当于数据库表中的所有行)。

  • 索引:字典的拼音检字表部首笔画目录

  • 工作流程

    1. 你要查“张”字。

    2. 你不会从第一页开始逐页翻找(全表扫描)。

    3. 你会先查拼音索引,找到“zhang”对应的页码范围,或者查部首索引,找到“弓”部对应的页码。

    4. 然后直接翻到该页码附近,快速找到“张”字(索引定位)。

在数据库中,这个过程被抽象为:

  1. 索引创建:数据库提取指定列(或列组合)的值,并根据特定的数据结构(如B+树、哈希表)进行组织,形成一个独立的索引文件。每条索引记录包含:索引键值+指向对应数据行位置的指针

  2. 索引查询

    • 当执行带有查询条件的SQL时(如WHERE name = ‘张三’),数据库优化器会先判断是否有可用的索引。

    • 如果有,则访问索引结构,利用其高效的查找算法(如在B+树中进行二分查找、在哈希表中直接计算地址)快速找到键值‘张三’及其对应的数据行指针。

    • 最后,通过指针直接定位并读取磁盘上的完整数据行。

三、两种主要索引实现原理的简要对比

虽然索引的核心思想一致,但不同数据结构决定了其特性和适用场景。

索引类型核心原理工作方式类比
哈希索引散列映射。对索引键值应用哈希函数,计算出一个唯一的(或近似唯一的)哈希码,直接映射到数据行的存储地址。类似于电话簿的人名索引。你知道“张三”的名字,通过名字的拼音(哈希计算)直接定位到其电话号码(数据地址)。只适合精确匹配
B+树索引平衡多路搜索树。所有键值在树中有序存储,非叶子节点存放键值和子节点指针,叶子节点存放键值、数据指针,并形成双向链表。类似于教材的目录。目录(索引)本身有章、节、小节的层级结构(树形),并且页码顺序排列。你可以快速定位到某一章(范围查找),也可以顺着链表翻到下一页。适合精确查找、范围查找和排序
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/13 15:31:35

基于大数据对B站热门视频的数据分析与数据研究系统(程序+文档+讲解)

课题介绍在 B 站内容生态精细化运营、创作者赋能需求下,传统热门视频分析存在 “维度单一、实时性差、规律挖掘不足” 的痛点,基于大数据技术构建的 B 站热门视频数据分析与研究系统,适配平台运营人员、UP 主、数据分析师等角色,整…

作者头像 李华
网站建设 2026/4/11 3:59:17

学长亲荐10个AI论文软件,助你轻松搞定本科毕业论文!

学长亲荐10个AI论文软件,助你轻松搞定本科毕业论文! 论文写作的“隐形助手”,你真的了解吗? 在当今这个信息爆炸的时代,AI 工具已经成为许多本科生撰写毕业论文时不可或缺的帮手。无论是内容创作、逻辑梳理&#xff0c…

作者头像 李华
网站建设 2026/4/14 4:58:48

佳明自动驾驶系统成功实现小型飞机无人干预自动着陆

美国联邦航空管理局证实,佳明公司的自动着陆产品在首次实际紧急情况应用中取得成功,一架小型飞机在科罗拉多州落基山都市机场完全依靠自动化系统安全紧急降落。佳明紧急自动着陆系统的设计目标是在"飞行员无法驾驶的紧急情况下自动接管飞行的完全控…

作者头像 李华
网站建设 2026/4/10 19:31:23

运营述职 PPT 工具横评:效率与呈现谁更优

每到季度末,做运营述职 PPT 就成了运营人的噩梦。好不容易搞定了基础的数据整理,又要担心写不出吸引人的内容,熬夜熬到两眼发黑,内容框架还是一团乱麻。好不容易把内容凑齐了,又得在排版设计上绞尽脑汁,颜色…

作者头像 李华
网站建设 2026/4/15 12:01:43

基于微信小程序的新冠疫情防控信息管理系统毕设源码+文档+讲解视频

前言 本课题聚焦新冠疫情防控场景下信息管理的高效化需求,针对传统防控信息收集滞后、数据分散、交互不便等痛点,设计开发基于微信小程序的新冠疫情防控信息管理系统。系统以微信小程序为前端载体,结合Node.jsExpress后端框架与MongoDB数据库…

作者头像 李华
网站建设 2026/4/15 12:02:41

使用OpenGL绘制卡通效果的圣诞树

使用OpenGL绘制卡通效果的圣诞树引言1. 加载3D圣诞树模型1.1 模型准备1.2 使用Assimp库加载模型2. 使用OpenGL绘制圣诞树2.1 初始化OpenGL2.2 设置着色器3. 添加卡通效果3.1 卡通着色原理3.2 实现卡通着色3.3 添加轮廓线4. 增强圣诞气氛4.1 装饰品4.2 闪烁灯光4.3 雪花粒子系统…

作者头像 李华