news 2026/4/18 11:55:38

索引的原理

作者头像

张小明

前端开发工程师

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

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

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

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

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

以汉语字典为例:

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

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

  • 工作流程

    1. 你要查“张”字。

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

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

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

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

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

  2. 索引查询

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

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

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

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

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

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

基于AI智能名片链动2+1模式S2B2C商城小程序的商户端微商平台构建研究

摘要:在数字化商业浪潮下,商户端微商面临激烈竞争,需构建全面且高效的平台体系。本文聚焦AI智能名片链动21模式S2B2C商城小程序在商户端微商平台构建中的应用,从技术、宣传、资源三个平台维度展开研究。通过分析该模式在各平台的作…

作者头像 李华
网站建设 2026/4/18 8:20:45

专注充电桩投资,招募城市合伙人 - 慧知开源充电桩平台

专注充电桩投资,招募城市合伙人 - 慧知开源充电桩平台 我们提供资本与战略,您负责落地与执行。本团队的核心业务是 投资建设充电桩,并作为您的投资人兼战略顾问:投入全部资金,并在选址、技术、资源等关键环节提供支持&…

作者头像 李华
网站建设 2026/4/18 6:24:01

Java毕设选题推荐:基于vue+协同过滤算法的动漫推荐系统热门动漫浏览、文章专栏阅读【附源码、mysql、文档、调试+代码讲解+全bao等】

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华
网站建设 2026/4/18 6:30:52

两种常见开关中断方式对比

经常会遇到两种典型的中断禁用 / 启用实现:一种是基于纯汇编编写的Arch_IntSave/Arch_IntDisable函数,另一种是编译器内置的__enable_irq/__disable_irq内联函数,这两种的区别和功能具体拆解一下。一、核心实现与功能拆解1. 纯汇编实现&#…

作者头像 李华
网站建设 2026/4/18 6:29:10

城市仿真软件:CityEngine_(11).城市规划与设计实践

城市规划与设计实践 在上一节中,我们探讨了城市仿真软件的基本功能和应用场景。接下来,我们将深入到城市规划与设计的实践部分,通过具体的案例和代码示例,展示如何利用CityEngine进行城市模型的创建、编辑和仿真。本节将涵盖以下…

作者头像 李华
网站建设 2026/4/18 8:47:46

MySQL介绍

一、MySQL1. MySQL是什么?(简单直白版)想象一下,你开了一家超级棒的奶茶店,每天要记录:顾客点的奶茶口味顾客的联系方式每天的销售数据仓库里的原料库存如果用Excel表格记录,当数据量达到10万条…

作者头像 李华