千家信息网

MySQL的索引有什么作用

发表于:2025-02-02 作者:千家信息网编辑
千家信息网最后更新 2025年02月02日,本篇内容主要讲解"MySQL的索引有什么作用",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"MySQL的索引有什么作用"吧!为什么用了索引之后,查询就会变快
千家信息网最后更新 2025年02月02日MySQL的索引有什么作用

本篇内容主要讲解"MySQL的索引有什么作用",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"MySQL的索引有什么作用"吧!

为什么用了索引之后,查询就会变快?

相信很多程序员朋友对数据的索引并不陌生,最常见的索引是 B+ Tree 索引,索引可以加快数据库的检索速度,但是会降低新增、修改、删除操作的速度,一些错误的写法会导致索引失效等等。

但是如果被问到,为什么用了索引之后,查询就会变快?B+ Tree 索引的原理是什么?这时候很多人可能就不知道了,今天我就以 MySQL 的 InnoDB 引擎为例,讲一讲 B+ Tree 索引的原理。

索引的基础知识

MySQL 的基本存储结构是页,大概就是这个样子的:

在这里,我们需要了解以下几点(非常重要):

  • 当我们用 MySQL 的 InnoDB 引擎创建表,有且只能有一个主键;如果我们没有显示地指定之间,那么MySQL 会自动生成一个隐含字段作为主键;

  • 聚集索引:以主键创建的索引;聚集索引的叶子节点存储的是表中的数据;

  • 非聚集索引:非主键创建的索引;非聚集索引在叶子节点存储的是主键和索引列;使用非聚集索引查询数据,会查询到叶子上的主键,再根据主键查到数据(这个过程叫做回表)。

页和页之间、页和数据之间的关系

我们以聚集索引做讲解,页和页之间、以及页和数据之间的关系是这样的:

  • 数据页和数据页之间,组成一个双向链表;

  • 每个数据页中的记录,是一个单向链表;

  • 每个数据页都根据内部的记录生成一个页目录(Page directory),如果是主键的话,可以在页目录中使用二分法快速定位;

  • 如果我们根据一个非主键、非索引列进行查询,那么需要遍历双向链表,找到所在的页;再遍历页内的单向链表;如果表内数据很大的话,这样的查询就会很慢。

B+ Tree 索引的原理

先让我们看看 B+ Tree 索引大概是什么样子(以聚集/主键索引为例):

  • 假如这时候我们要查询 id = 16 的数据:

  • 查询页-1,找到页-2 存储的是小于 30 的数据;

  • 查询页-2,找到页-5 存储的是 10~20 的数据;

  • 查询页-5,找到 id = 16 的数据。

很显然,没有用索引的时候,需要遍历双向链表来定位对应的页,而有了索引,则可以通过一层层"目录"定位到对应的页上。

为什么 B+ Tree 索引会降低新增、修改、删除的速度

  • B+ Tree 是一颗平衡树,如果对这颗树新增、修改、删除的话,会破坏它的原有结构;

  • 我们在做数据新增、修改、删除的时候,需要花额外的时间去维护索引;

  • 正因为这些额外的开销,导致索引会降低新增、修改、删除的速度。

到此,相信大家对"MySQL的索引有什么作用"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

索引 数据 查询 之间 存储 速度 作用 原理 双向 叶子 目录 定位 内容 单向 引擎 时候 朋友 样子 结构 节点 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 雷神科技与互联网 上海服务软件开发教育 阿里轻量云服务器怎么使用教程 服务器上的hdd亮红灯 吉林互联网软件开发诚信服务 定时将某个文件夹新增文件上传到服务器 javac编译连接数据库 万方数据库怎么看涉及基金项目 大连招聘软件开发工程师 图书馆数据库安全保障制度 安居宝添加电脑服务器ip地址 如何做一台共享服务器 计算机网络技术基础总结报告 十堰市网络安全宣传周线上答题 山西云服务器 履行新时代网络安全使命 中国网络安全审查技术与资质 计算机网络技术实验题 如何构建网络安全防护系统 网络安全构成威胁的类型 河南光纤服务器云空间 世界互联网专访鸭梨科技 网络技术应用操作题会考 网络安全生态什么和谐社会 河北海群网络技术有限公司 数据库开发需要硕士学历 网络安全工程师能考什么证 上海科技互联网有限公司 淄博网络安全赛 软件开发潜能
0