MySQL之InnoDB存储引擎中的索引用法及说明

2025-06-26 17:50

本文主要是介绍MySQL之InnoDB存储引擎中的索引用法及说明,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《MySQL之InnoDB存储引擎中的索引用法及说明》:本文主要介绍MySQL之InnoDB存储引擎中的索引用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐...

1、背景

InnoDB存储引擎的基本存储单位是页,索引也是存储在页上的,B+树中非叶子节点的页也是数据页,和我们插入数据的区别是存放的行记录叫目录项记录,我们插入的行记录叫用户记录

B+树由叶子节点和非叶子节点组成,叶子节点只有一层,用来存放用户记录,非叶子节点可以由一层或多层组成,用来存放目录项记录。

B+树这种结构是为了方便我们查找想要的数据,可以将B+树这种结构叫索引,建议先参考一下上篇文章讲解的,接下来我们就来学习一下索引到底是什么。

2、准备

创建一个表并插入一些数据用来演示索引:

#创建表
CREATE TABLE test
(
    id INT AUTO_INCREMENT PRIMARY KEY,
    str VARCHAR(255) NOT NULL DEFAULT ''
) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4;

#插入数据
INSERT INTO test (str)
VALUES ('AAA'),
       ('BBB'),
       ('CCC');

查看记录:

mysql [xxx]> select * from test;
+----+-----+
| id | str |
+----+-----+
|  1 | AAA |
|  2 | BBB |
|  3 | CCC |
+----+-----+
3 rows in set (0.001 sec)

3、正篇

【1】存储用户记录的数据页

上面的3条记录可以用如下图表示,为了简介只展示主要字段:

MySQL之InnoDB存储引擎中的索引用法及说明

一个页面上的主键是顺序排列的,当要通过主键查找数据时,如果数据全在一张页上,通过二分法很快就能找到所查找的主键,但如果我们不通过主键查找数据,或者www.chinasem.cn数据在很多张页上,页之间并不是连续存储的,这个时候就要遍历所有页所有数据,索引就是为解决这个问题而生的。

【2】存储目录项记录的数据页

目录项记录和用户记录的区别就是record_type的值为1,也代表B+树非叶子节点记录,还有一个区别就是min_rec_mask(B+树非叶子节点中的最小记录)不同,给一个3层B+树的例子如图:

MySQL之InnoDB存储引擎中的索引用法及说明

从上网往下数,最上面一层叫根节点,第二层叫非叶子节点,第三层叫叶子节点。

1、根节点和非叶子节点中的目录项记录根据主键大小进行排序,最左边的记录主键id在这个页中最小,所以它的min_rec_mask属性为1,根节点只有一个页,对根节点的目录项记录进行二分法很快就能找到下一个层级的数据页,然后再进行二分法得到要查的页,最后再对页里的用户数据进行二分法找到指定的记录。

2、叶子节点只有一层,叶子节点的页全部是用来存储用户记录。

【3】聚簇索引

主键索引就是聚簇索引,聚簇索引,满足以下条件:

  • 1、一个页上的所有用户记录或者目录项记录根据主键大小形python成一个单向链表。
  • 2、B+树同一层级的所有页根据主键大小形成一个双向链表。
  • 3、B+树叶子节点存放用户项记录包含所有列的数据。

【4】二级索引

聚簇索引只有在根据主键进行查找的时候能使用对应的B+树,根据其它列去查找时就要进行全表扫描了,我们给上述例子中str列也设置索引:

ALTER TABLE test ADD INDEX str (str);

设置完之后会产出一颗新的B+树,如图:

MySQL之InnoDB存储引擎中的索引用法及说明

str列建的B+树由如下特性:

1、页里的目录项记录和用户记录根据str列大小组成一个单向链表。

2、每层节点的所有页根据str列大小组成一个双向链表。

3、叶子节点存储的数据部分其实只有str列和主键大小,因为这里建表的列字段只有str列和主键,假如有多个列,要想知道其它列的信息,我们就得根据查出来的str列对应的主键到聚簇随意对应的B+树javascript里去找到其它列数据,这种查找方式就叫"回表"。

我们这里只有主键和str两列,所以不需要回表就能得到所有列的数据,这种需要最多进行一次回表的B+树,被称为"二级索引"。

二级索引对应的目录项记录有个要注意的地方:

并不是只存储了str列和页号,还存储了主键值,这是为了插入记录的str列相同时,需要根据主键的不同来确定将记录插入到哪个页。

【5】组合索引

给多个列建一颗B+树就叫组合索引,假设有这样一个表:

CREATE TABLE test
(
    id INT AUTO_INCREMENT PRIMARY KEY,
    str1 VARCHAR(255) NOT NULL DEFAULT '',
    str2 VAwww.chinasem.cnRCHAR(255),
    str3 CHAR(5)
) ENGINE = InnoDB DEFAULT CHARSET = utf8mb4;

建立组合索引的sql语句:

ALTER TABLE test ADD INDEX str1_str2android_str3 (str1, str2, str3);

上面组合索引有这样的特性:

  • 1、所有页和行记录先根据str1的大小顺序进行排列。
  • 2、在str1相同的情况下根据str2的大小顺序进行排列。
  • 3、在str2相同的情况下再根据str3的大小顺序进行排列。
  • 4、B+树中的所有页和页里所有行记录会根据3个列的大小分别组成双向链表和单向链表。

4、总结

通过本文学习到了,索引就是B+树对应的结构,放了方便我们根据某列快速找到想要的记录,根据B+ 树的不同又可以分为:聚簇索引、二级索引、组合索引。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持China编程(www.chinasem.cn)。

这篇关于MySQL之InnoDB存储引擎中的索引用法及说明的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1155227

相关文章

浅谈MySQL的容量规划

《浅谈MySQL的容量规划》进行MySQL的容量规划是确保数据库能够在当前和未来的负载下顺利运行的重要步骤,容量规划包括评估当前资源使用情况、预测未来增长、调整配置和硬件资源等,感兴趣的可以了解一下... 目录一、评估当前资源使用情况1.1 磁盘空间使用1.2 内存使用1.3 CPU使用1.4 网络带宽二、

MySQL ORDER BY 语句常见用法、示例详解

《MySQLORDERBY语句常见用法、示例详解》ORDERBY是结构化查询语言(SQL)中的关键字,隶属于SELECT语句的子句结构,用于对查询结果集按指定列进行排序,本文给大家介绍MySQL... 目录mysql ORDER BY 语句详细说明1.基本语法2.排序方向详解3.多列排序4.常见用法示例5.

MySQL数据类型与表操作全指南( 从基础到高级实践)

《MySQL数据类型与表操作全指南(从基础到高级实践)》本文详解MySQL数据类型分类(数值、日期/时间、字符串)及表操作(创建、修改、维护),涵盖优化技巧如数据类型选择、备份、分区,强调规范设计与... 目录mysql数据类型详解数值类型日期时间类型字符串类型表操作全解析创建表修改表结构添加列修改列删除列

SQLServer中生成雪花ID(Snowflake ID)的实现方法

《SQLServer中生成雪花ID(SnowflakeID)的实现方法》:本文主要介绍在SQLServer中生成雪花ID(SnowflakeID)的实现方法,文中通过示例代码介绍的非常详细,... 目录前言认识雪花ID雪花ID的核心特点雪花ID的结构(64位)雪花ID的优势雪花ID的局限性雪花ID的应用场景

DNS查询的利器! linux的dig命令基本用法详解

《DNS查询的利器!linux的dig命令基本用法详解》dig命令可以查询各种类型DNS记录信息,下面我们将通过实际示例和dig命令常用参数来详细说明如何使用dig实用程序... dig(Domain Information Groper)是一款功能强大的 linux 命令行实用程序,通过查询名称服务器并输

MySQL中DATE_FORMAT时间函数的使用小结

《MySQL中DATE_FORMAT时间函数的使用小结》本文主要介绍了MySQL中DATE_FORMAT时间函数的使用小结,用于格式化日期/时间字段,可提取年月、统计月份数据、精确到天,对大家的学习或... 目录前言DATE_FORMAT时间函数总结前言mysql可以使用DATE_FORMAT获取日期字段

在 Spring Boot 中连接 MySQL 数据库的详细步骤

《在SpringBoot中连接MySQL数据库的详细步骤》本文介绍了SpringBoot连接MySQL数据库的流程,添加依赖、配置连接信息、创建实体类与仓库接口,通过自动配置实现数据库操作,... 目录一、添加依赖二、配置数据库连接三、创建实体类四、创建仓库接口五、创建服务类六、创建控制器七、运行应用程序八

Java中数组与栈和堆之间的关系说明

《Java中数组与栈和堆之间的关系说明》文章讲解了Java数组的初始化方式、内存存储机制、引用传递特性及遍历、排序、拷贝技巧,强调引用数据类型方法调用时形参可能修改实参,但需注意引用指向单一对象的特性... 目录Java中数组与栈和堆的关系遍历数组接下来是一些编程小技巧总结Java中数组与栈和堆的关系关于

MySQL 升级到8.4版本的完整流程及操作方法

《MySQL升级到8.4版本的完整流程及操作方法》本文详细说明了MySQL升级至8.4的完整流程,涵盖升级前准备(备份、兼容性检查)、支持路径(原地、逻辑导出、复制)、关键变更(空间索引、保留关键字... 目录一、升级前准备 (3.1 Before You Begin)二、升级路径 (3.2 Upgrade

MySQL连表查询之笛卡尔积查询的详细过程讲解

《MySQL连表查询之笛卡尔积查询的详细过程讲解》在使用MySQL或任何关系型数据库进行多表查询时,如果连接条件设置不当,就可能发生所谓的笛卡尔积现象,:本文主要介绍MySQL连表查询之笛卡尔积查... 目录一、笛卡尔积的数学本质二、mysql中的实现机制1. 显式语法2. 隐式语法3. 执行原理(以Nes