MySQL InnoDB存储引擎体系架构支持的索引是什么

技术MySQL InnoDB存储引擎体系架构支持的索引是什么本篇文章为大家展示了MySQL InnoDB存储引擎体系架构支持的索引是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收

本文向您展示了MySQL InnoDB存储引擎架构支持哪些索引。内容简洁易懂,一定会让你眼前一亮。希望通过这篇文章的详细介绍,你能有所收获。

众所周知,在MySQL的InnoDB引擎中,为了提高查询速度,可以给字段添加索引。索引就像一个图书目录,一本书的内容可以通过目录定位到哪一页。

InnoDB支持几个索引:

b树索引

全文索引

散列索引

关注B-树索引。

一、数据结构——B树。

相信大家在大学的数据结构课程中都学过二分搜索法,二叉树,平衡二叉树。在一组有序的数据中,二分搜索法可以快速检索log2N复杂度的数据。平衡二叉树由二叉查找树演化而来,解决了二叉查找树在极端情况下转化为单链表的问题。b树呢?我们来看看B树的结构。

MySQL  InnoDB存储引擎体系架构支持的索引是什么

在B树中,数据按照从下到上的顺序存储在叶节点中。从上图的B-tree可以得出,这个B-tree的高度是2,每页可以存储4条数据,扇出是5。第一层是索引页,第二层是数据页。B-tree索引的本质是B-tree在数据库中的实现,B-tree的高度一般限制在2-4层,磁盘的IO操作只需要2-4次,在索引上查找数据非常快。

二是B-树索引。

1.聚集索引。

在InnoDB引擎中,有一个聚集索引,它通常是一个主键。如果用户没有显示指定的主键,InnoDB会选择默认情况下不为null的表的第一个唯一索引作为主键,否则会自动创建一个6字节的_rowid作为主键。

MySQL  InnoDB存储引擎体系架构支持的索引是什么

上图是聚集索引示意图。从上图我们可以看到,树分为两层,第一层是索引页,第二层是数据页,这其实就是数据存储的地方。我们还可以得出结论,索引页存储的不是数据,而是指向真实数据的偏移量,真实数据存储在第二层的数据页中。因此,如果一条SQL语句命中索引,它只命中索引页的数据,然后通过索引页找到真正数据所在的页。

聚集索引的存储不是物理上连续的,而是逻辑上连续的,因为页是由双链表维护的,每页的行记录也是由双链表维护的。为什么是双链表?这是因为它便于范围查询和排序,例如查找索引所在的数据页的偏移量、直接遍历链表或反向遍历链表。例如

从表中选择*其中id10和id1000

2.辅助索引。

InnoDB的另一个索引,辅助索引,也称为二级索引或非聚集索引。对于辅助索引,叶不包含行中记录的所有数据。除了键值之外,叶节点还包含一个叫做“书签”的东西,用来告诉InnoDB在哪里可以找到需要的行数据,所以书签实际上是存储聚集索引的。因此,如果SQL命中辅助索引,查询过程将分为两个步骤:

1.找到索引页。

2.通过索引页查找数据页,该页包含聚集索引的值。

3.通过聚集索引查找行记录。

因此,辅助索引一般比聚集索引多一个IO。

MySQL  InnoDB存储引擎体系架构支持的索引是什么

一个容易被DBA忽略的问题:如果一条SQL语句命中索引,B-tree索引找不到给定查询条件的特定行,只能找到查询到的数据行所在的页面,然后将数据读入内存,然后在内存中遍历所有行找到数据。此外,每页的大小为16k,每页将包含多行,并且行由双链表组织,因此在按逆序查询范围或排序时,只需遍历链表即可。

以上内容就是MySQL InnoDB存储引擎架构支持哪些索引。你学到什么知识或技能了吗?如果你想学习更多的技能或丰富你的知识储备,请关注行业信息渠道。

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/46788.html

(0)

相关推荐

  • 信息安全的基本属性有哪些

    技术信息安全的基本属性有哪些这篇文章主要讲解了“信息安全的基本属性有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“信息安全的基本属性有哪些”吧!

    攻略 2021年11月9日
  • 怎样进行debian apt mysql无密码安装

    技术怎样进行debian apt mysql无密码安装怎样进行debian apt mysql无密码安装,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能

    攻略 2021年11月30日
  • 拼多多可以用花呗吗,京东淘宝拼多多分别用什么付款

    技术拼多多可以用花呗吗,京东淘宝拼多多分别用什么付款京东是京东自己的白条或者网银还有微信拼多多可以用花呗吗,淘宝可以支付宝跟网银,
    拼多多可以微信或者支付宝还有网银。
    无论是淘宝还是京东,就目前来看,都属于两个做得非常大

    生活 2021年10月31日
  • 如何解析Burpsuite中的抓包配置

    技术如何解析Burpsuite中的抓包配置本篇文章给大家分享的是有关如何解析Burpsuite中的抓包配置,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一、

    攻略 2021年12月9日
  • C语言怎么实现内存对齐

    技术C语言怎么实现内存对齐这篇文章主要讲解了“C语言怎么实现内存对齐”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C语言怎么实现内存对齐”吧!  一、概念      

    攻略 2021年12月8日
  • Python机器学习k-近邻算法怎么实现

    技术Python机器学习k-近邻算法怎么实现这篇文章主要介绍“Python机器学习k-近邻算法怎么实现”,在日常操作中,相信很多人在Python机器学习k-近邻算法怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好

    攻略 2021年11月26日