谈谈MySQL索引?你真的了解它吗 ?

— — 写在前面

记得刚开始工作那会,年轻无知 [dog],有一段时间对 MySQL 的索引极为迷惑,看公司的 wiki 有着一堆的使用规则,于是我就挑了其中的一个询问了一位 年长的老湿傅,“为何联合索引要最左则原则?” ,湿傅:“这常识问题啊?就我们在使用的时候应该.......”。我 ....... 所以在回答别人问题的时候最好还是要有点深度准备好了再说,否则 [dog][dog][dog] 此处省略一万字 .....
后来经过业余时间的资料补充,可算是了解了一点皮毛,以此一来不管是在平时的使用、设计都有诸多的好处。最近又看到一些文章,于是决定我也来做碗汤,下文主要就围绕 Innodb 来讲解其页结构、B+ Tree 主键索引、及联合索引和普通索引。最后的答案也就随之浮现。为何会有这么多的使用原则?

一、索引的作用

索引,当然是为了提高查询或检索的效率。就举个通俗的栗子吧,我们在使用汉字字典拼音查询时,比如要查询 某个字时,是不是需要从其拼音的开头字母开始查询,慢慢缩小其查询的范围,最终找到匹配的拼音的索引页,定位到所要查询的字。而在数据库中索引的作用也是如此。

二、聚簇索引和非聚簇索引

对于聚簇索引,其实就是叶子节点的顺序和物理存储的顺序是一样的,所以其 范围查询效率很高,任何事物都是有两面性的,所以它的弊端就是在一些DML操作的时候,需要涉及到数据的位移。聚簇索引的顺序就是数据的物理储存顺序,所以这样一来,一个表就只能有一个聚簇索引。( MySQL Innodb 中默认为主键,当然没有定义主键, InnoDB 会隐式定义一个主键 )
对于非聚簇索引本文就不做太多介绍,其叶级页指向表中的记录行( 实际上就是内节点会存储指针,指向记录的物理地址 ),所以其物理顺序与逻辑顺序是没有联系的。

三、MySQL InnoDB 数据页结构

额 .... 这块其实内容比较多,围绕本文的核心,我就挑 Page Directory ( 页目录 ) 来说下吧。
上面说到查字典,总得有个目录去找到对应的数据吧 ( 有目录当然是为了更好的管理数据 )。在 InnoDB 中是分为数据页和索引页的。
所以 MySQL 为了方便管理这些记录,就规定了用页作为基本单位存放记录,默认的大小是 16 KB,所以一页能存放多少数据是由这些记录的大小决定的,比如一条记录的大小为 10字节的话,那么 16 * 1024 / 10 = 1,638.4 ,所以大约一页可以存放 1638 条记录( 理论值 )。那么数据量一多肯定会存在多页,那么页与页之间是怎么关联的呢?见下文图一。
Page和B+树之间并没有一一对应的关系,Page 只是作为一个 Record的 保存容器,它存在的目的是便于对磁盘空间进行批量管理。

图一 InnoDB 页目录剖析图

原图地址: https://www.processon.com/view/link/6077c33de0b34d16663efd0d

四、B+ 树 ( B+ Tree )

这里推荐大家一个网站,可以去模拟各种数据结构的插入、删除、转换过程。https://www.cs.usfca.edu/~galles/visualization/Algorithms.html
所以我这边在此 乱序 插入了一些数据( 7,8,9,12,15,18,24,27 ),生成了 Degree 为 3 的 B+ 树。

图二 B+ Tree 索引数据结构模拟

不难发现,其有以下特点:

  • 叶子结点包含了所有结点,除叶子结点之外,其它结点不包含值,而叶子结点包含具体的值
  • 层级更低( 相比B树,此文不做 B 树分析 ),叶子结点形成 链表( 有序 ),范围查询(留个心眼)方便;
    由此,经过一些官方资料查阅,画了一张 InnoDB 引擎中的 B+ 树索引的数据结构图:
    图三 InnoDB 索引数据结构

    原图地址:https://www.processon.com/view/link/6077a5ae0791293688854242

五、联合索引和普通索引

上文二中曾提到因为其本质结构原因一个表就只能有一个聚簇索引,而 InnoDB 默认的聚簇索引就是 主键,那么联合索引和普通索引在查询时是怎么使用的呢?
为此,根据个人的理解本人作图以便于更直观的理解。

图四 联合索引或普通索引检索流程( 回表 )

以此上图,当我们在新建一个普通索引或者联合索引时,回去维护类似上图的一个数据结构,当我们在查询时 MySQL 查询分析器选择的是普通索引时,会先通过索引字段找到普通索引数据页。从而找到对应数据的主键位置,再通过主键去检索到所对应的精确行。是不是感觉有点类似于非聚簇索引( 但是有区别哈 )。再观察上图,联合索引的排列方式,是不是一眼忘川了为何开发中经常提到的 最左则原则呢。

六、为何 MySQL 会选择 B+ 树作为索引?

A、相对于 B 树

读取成本( IO 次数 ):B+树的非叶子结点没有存储数据,所以如果把所有同一内部节点的关键字存放在同一盘块中,那么盘块所能容纳的关键字数量也越多。一次性读内存中的需要查找的关键字也就越多。
查询效率:由于B+树的分支结点并不是最终指向文件内容的结点,只是叶子结点的索引,所以任意关键字的查找都必须从根节点走向分支结点,查询路径相同。但B树的分支结点保存有数据,所以查询路径可能不同。

B、相对于 Hash 索引

Hash 应该无需多言了,Hash 的优势是在于精确定位查询,常见的有 HashMap ,但不适合做范围查询
Hash 索引每次查询时都需要将所有的索引数据加载到内存中,而 B+ 索引只需要选定某个范围,再加载到内存中,进行检索。

写在最后

自下而上的分析,根据文章中一些标红的地方,不难发现也就是 MySQL 的一些优势和一些规则的来源也就浮现出来了。另外,了解这些东西只是为了更加清晰的对 MySQL 索引有个稍微深层次的一个认知,才能够运用得当。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,240评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,328评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,182评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,121评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,135评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,093评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,013评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,854评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,295评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,513评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,678评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,398评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,989评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,636评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,801评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,657评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,558评论 2 352

推荐阅读更多精彩内容