MySQL索引的原理

MySQL索引的原理

mysql数据库支持多种索引,例如b树索引、哈希索引、全文索引等,本文着重讲解下b树索引。(推荐:《mysql教程》)

索引原理&本质

MySQL官方解释:索引是为MySQL提高获取数据效率的数据结构,为了快速查询数据。索引是满足某种特定查找算法的数据结构,而这些数据结构会以某种方式指向数据,从而实现高效查找数据。

B+树

MySQL一般以B+树作为其索引结构,那么B+树有什么特点呢?

树度为n的话,每个节点指针上限为2n+1

非叶子节点不存储数据,只存储指针索引;叶子节点存储所有数据,不存储指针

在经典B+树基础上增加了顺序访问指针,每个叶子节点都有指向相邻下一个叶子节点的指针,如图所示。主要为了提高区间访问的性能,例如要找key为20到50的所有数据,只要按着顺序访问路线一次性访问所有数据节点。

纳米搜索 纳米搜索

纳米搜索:360推出的新一代AI搜索引擎

纳米搜索 30 查看详情 纳米搜索

10ef020552105aa298b03389f7d696c.png

带顺序访问的B+树简图

局部性原理和磁盘预读

那么为什么数据库系统普遍使用B+树作为索引结构,而不选例如红黑树其他结构呢?

首先要先来介绍下局部性原理和磁盘预读的概念。

一般来说,索引本身较大,不会全部存储在内存中,会以索引文件的形式存储在磁盘上。所以索引查找数据过程中就会产生磁盘IO操作,而磁盘IO相对于内存存取非常缓慢,因此索引结构要尽量减少磁盘IO的存取次数。

为了减少磁盘IO,磁盘往往会进行数据预读,会从某位置开始,预先向后读取一定长度的数据放入内存,即局部性原理。因为磁盘顺序读取的效率较高,不需要寻道时间,因此可以提高IO效率。

预读长度一般为页的整数倍,主存和磁盘以页作为单位交换数据。当需要读取的数据不在内存时,触发缺页中断,系统会向磁盘发出读取磁盘数据的请求,磁盘找到数据的起始位置并向后连续读取一页或几页数据载入内存,然后中断返回,系统继续运行。而一般数据库系统设计时会将B+树节点的大小设置为一页,这样每个节点的载入只需要一次IO。

以上就是MySQL索引的原理的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/366571.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月6日 05:32:38
下一篇 2025年11月6日 05:35:51

相关推荐

  • 如何在mysql中分析索引命中率

    通过EXPLAIN、慢查询日志、performance_schema和状态变量可评估MySQL索引使用情况:1. EXPLAIN的type、key、rows和Extra字段显示单条SQL索引命中详情;2. 慢查询日志中Rows_examined大但返回行少的语句可能未有效使用索引;3. perfor…

    2025年12月6日 数据库
    000
  • mysql如何查看表的索引顺序 mysql表索引字段顺序查看教程

    要查看mysql表的索引字段顺序,最直接的方法是使用show index from your_table_name命令或查询information_schema.statistics表,其中seq_in_index字段明确指示了各字段在索引中的排列顺序,从1开始递增,通过这两种方式可清晰了解复合索引…

    2025年12月3日
    000
  • MySQL前缀索引导致的慢查询

    前端时间跟一个DB相关的项目,alanc反馈有一个查询,使用索引比不使用索引慢很多倍,有点毁三观。所以跟进了一下,用explain,看 前端时间跟一个db相关的项目,alanc反馈有一个查询,使用索引比不使用索引慢很多倍,有点毁三观。所以跟进了一下,用explain,看了看2个查询不同的结果。 不用…

    2025年12月2日 数据库
    000
  • mysql索引学习教程_MySQL

    在mysql 中,索引可以分为两种类型 hash索引和 btree索引。 什么情况下可以用到B树索引? 1.全值匹配索引 比如: orderID=”123” 2.匹配最左前缀索引查询 比如:在userid 和 date字段上创建联合索引。那么如果输入 userId作为条件,那么这个use…

    2025年12月2日
    000
  • 如何使用mysql索引_mysql索引操作方法解析

    答案:MySQL索引可提升查询效率,需合理创建、查看、修改和删除。创建支持建表时定义或使用CREATE INDEX、ALTER TABLE添加;唯一索引用UNIQUE,主键自动创建;复合索引遵循最左前缀原则。通过SHOW INDEX、SHOW CREATE TABLE或information_sch…

    2025年12月2日 数据库
    000
  • 如何在mysql中分析索引命中率_mysql索引命中率分析方法

    索引命中率是评估MySQL查询效率的关键指标,通过Handler_read_key与Handler_read_rnd_next计算,理想值应接近100%,低于90%需优化索引或SQL。 MySQL索引命中率是衡量查询是否有效利用索引的重要指标。高命中率说明大部分索引查找都成功匹配了数据,低命中率则可…

    2025年12月2日 数据库
    000
  • mysql如何优化索引顺序_mysql索引顺序优化技巧

    合理设计复合索引顺序可显著提升查询性能。1. 遵循最左前缀原则,查询必须从索引最左列开始,中间不跳列;2. 将高选择性列前置,选择性=去重值/总行数,越接近1越好;3. 匹配查询模式,使索引支持WHERE、ORDER BY和GROUP BY,避免filesort;4. 等值查询列在前,范围查询列在后…

    2025年12月2日 数据库
    000
  • mysql中索引选择性如何影响查询_mysql索引选择性优化方法

    索引选择性是唯一值数量与总行数的比值,比值越高,索引效率越高;应优先在高选择性列如用户ID、订单号上建索引,避免在性别、状态等低基数列单独建索引,否则易被优化器忽略。 索引选择性是指索引列中不同值的数量与表中总行数的比值,通常用公式:选择性 = 唯一值数量 / 总行数。选择性越高,说明该列区分度越好…

    2025年12月2日 数据库
    000
  • 如何在mysql中创建索引_mysql索引创建方法解析

    索引能显著提升MySQL查询性能,适用于WHERE、JOIN、ORDER BY等场景;可通过CREATE INDEX、建表时定义或ALTER TABLE添加;需遵循最左前缀原则,避免过多索引影响写性能,并结合EXPLAIN分析执行计划优化使用。 在MySQL中创建索引是提升查询性能的重要手段。合理使…

    2025年12月2日 数据库
    000
  • mysql中如何分析索引使用情况_mysql索引使用分析方法

    通过EXPLAIN、INFORMATION_SCHEMA、performance_schema、慢查询日志等方法可分析MySQL索引使用情况,识别未使用或冗余索引,优化查询性能。 在MySQL中,分析索引使用情况是优化查询性能的关键步骤。通过了解哪些索引被实际使用、哪些未被利用或冗余,可以有效提升数…

    2025年12月2日 数据库
    000
  • mysql如何使用索引覆盖查询_mysql索引覆盖查询方法

    索引覆盖查询指查询所需字段均在索引中,无需回表。例如SELECT name, age FROM user_info WHERE name = ‘Tom’使用idx_name_age索引,Extra显示Using index即为覆盖。 在MySQL中,索引覆盖查询(Coveri…

    2025年12月2日 数据库
    000
  • mysql数据库索引类型有哪些_mysql索引类型解析

    MySQL常见索引类型包括:1. 普通索引,用于加速查询,允许重复和NULL值;2. 唯一索引,保证字段值唯一,允许一个NULL,适用于身份证、邮箱等;3. 主键索引,特殊的唯一索引,不允许NULL,每表仅一个,建议设自增主键;4. 全文索引,支持文本关键词搜索,适用于大字段模糊查询;5. 组合索引…

    2025年12月2日 数据库
    000
  • 如何在mysql中使用索引提示_mysql索引提示优化方法

    %ignore_a_1%提示可优化MySQL查询执行计划。USE INDEX建议使用某索引,如SELECT FROM users USE INDEX (idx_email) WHERE email = ‘test@example.com’;FORCE INDEX强制使用指定索…

    2025年12月2日 数据库
    000
  • mysql索引失效的原因有哪些_mysql索引失效排查方法

    索引失效主因包括函数操作、否定查询、OR连接无索引字段、前导模糊匹配、类型转换、联合索引违背最左原则及大数据量回表;通过EXPLAIN分析执行计划,检查索引设计与SQL写法,避免隐式转换,可有效排查并优化。 MySQL索引失效会显著影响查询性能,导致原本应走索引的查询变成全表扫描。了解索引失效的原因…

    2025年12月2日 数据库
    000
  • mysql索引的基本原理

    MySQL索引通过B+树等数据结构提升查询效率,类似书籍目录避免全表扫描。1. B+树所有数据存于叶子节点,非叶子节点仅存索引,降低磁盘I/O;2. 叶子节点用指针连接,支持高效范围查询;3. 树高通常2~3层,查找稳定快速。哈希索引适用于等值查询,不支持范围或排序。主键索引唯一非空,InnoDB中…

    2025年12月2日 数据库
    000
  • mysql索引建立的原则

    合理建立索引需遵循:1. 选择高区分度列,如手机号优于性别;2. 多条件查询优先用联合索引并遵守最左前缀原则;3. 控制索引数量以降低写开销;4. 利用覆盖索引避免回表;5. 避免在索引列使用函数导致失效;6. 主键选用自增整数减少碎片;7. 大字段慎用索引,可选前缀或全文索引。 在MySQL中,合…

    2025年12月2日 数据库
    000
  • mysql索引覆盖如何做到_mysql覆盖索引解析

    覆盖索引是指查询所需字段均包含在某个索引中,无需回表获取数据。例如在users表中对(name, age)建立联合索引后,执行SELECT name, age FROM users WHERE name = ‘John’可直接从索引获取数据,执行计划的Extra显示Using…

    2025年12月2日 数据库
    000
  • MySQL中B+树索引的管理

    目前mysql数据库存在的一个普遍的问题是,所有对于索引的添加或者删除操作,mysql数据库是先创建一张新的临时表,然后把数据导入 索引的创建和删除可以通过两种方法;一种是alter table ,另一种是create /drop index.alter table 创建索引的语法:alter ta…

    数据库 2025年12月2日
    000
  • mysql数据库索引类型有哪几种?建立方法和优缺点

    本文将着重描述masql数据库索引的四种类型,数据库索引怎么建立?在WHERE和JOIN中出现的列需要建立索引,但也不完全如此,因为MySQL只对<,,>=,BETWEEN,IN,以及某些时候的LIKE才会使用索引。希望本文能帮助到大家,首先先来了解索引是什么吧,用一句话概括就是: 索引…

    2025年12月2日
    000
  • MySQL索引覆盖查询与性能提升_优化读取速度的必备技能

    索引覆盖查询能大幅提升mysql读取性能的核心原因在于减少磁盘i/o、提高缓存命中率、降低网络传输。1. 它避免了回表操作,直接从索引中获取所有数据,显著减少随机磁盘访问;2. 索引体积小更易被加载到内存,提升缓存命中率从而加速查询;3. 减少了从服务器到客户端的数据传输量,优化整体响应速度。 My…

    2025年12月2日 数据库
    000

发表回复

登录后才能评论
关注微信