高性能Mysql(3)-索引原理

1.mysql索引类型

1.1B-树索引

(B-树就是所说的B树)
使用树状结构存储数据库索引可以保证有序性而且查询效率也很高,但是为什么数据库的索引没有使用二叉查找树O(logN)来实现数据库的索引那?因为我们不得不考虑一个很现实的问题那就是数据库的索引是存储在硬盘上的,当数据量比较大的时候,索引甚至可能有几个G,我们无法将索引一次加入到内存当中,只能逐页的加载每一个磁盘页。最坏的情况下磁盘IO的次数就是树的深度。为了减少磁盘IO次数我们就要降低树的高度。
B树是一种多路平衡查找树,它的每一个结点最多包含K个孩子,k称为B树的阶,k取决于磁盘页的大小。

1.1.1一个m阶的B树必须满足以下条件:

1.根结点至少有两个子女。
2.每个非叶子节点都包含k-1个元素和k个孩子,其中 m/2 <= k <= m
3.每一个叶子节点都包含k-1个元素,其中 m/2 <= k <= m
4.所有的叶子结点都位于同一层。
5.每个节点中的元素从小到大排列,节点当中k-1个元素正好是k个孩子包含的元素的值域分划。

1 2 3 5 6 8 9 11 12 13 15
m=3;
k={2,3}
非叶子节点孩子={2,3}
非叶子节点元素={1, 2}
叶子节点元素= {1,2}
图片.png

利用这种特性可以减少磁盘IO的次数,虽然可能查询的次数变多一点但是相比于磁盘IO的速度内存耗时几乎可以忽略不计。

1.1.2B树如何插入删除

假如要插入4

自上到下查找发现3<4<=5,但是节点3,5已经是两元素节点,无法再增加。父亲节点 {2,6 }也是两元素节点,也无法再增加。根节点9是单元素节点,可以升级为两元素节点。于是拆分节点{3,5}与节点{2,6},让根节点9升级为两元素节点{4,9}。节点6独立为根节点的第二个孩子。

图片.png

虽然很复杂但是这也是B树的优势:自平衡

假如要删除11

删除11后,节点12只有一个孩子,不符合B树规范。因此找出12,13,15三个节点的中位数13,取代节点12,而节点12自身下移成为第一个孩子。(这个过程称为左旋)

图片.png

1.2B+树

当索引项比较多的时候,不能一次装入内存,可以对索引再建立索引,形成多级索引。

1.2.1B+树的特征

一个m阶的B+树具有如下几个特征:
除了和B树有相同的特征外B+树还要满足以下的特征
1.非叶子节点包含有k个元素(B树中是k-1个元素),每个元素不保存数据,只用来索引,所有数据都保存在叶子节点。m/2<=k<=m

2.所有的叶子结点中包含了全部元素的信息,及指向含这些元素记录的指针,且叶子结点本身依关键字的大小自小而大顺序链接。

3.所有的非叶子节点元素都同时存在于子节点,在子节点元素中是最大(或最小)元素

图片.png

在B+树中所有的叶子节点覆盖所有的数据记录,而非叶子节点只保存了索引,B树要所有的节点才能覆盖所有的数据记录。而且B+树的叶子节点形成了一个有序的链表。

1.2.2B+树的优势

  • 单行查询
    因为B+树的非叶子节点并不存储数据记录,而是只存储索引所以相同大小的磁盘也可以存储更多的节点元素,所以在单行查询时磁盘IO的次数更少。并且B+树查询最终查询必须在叶子节点上,而B树最好的情况只查询根节点,最坏要要查询叶子节点,所以B+树是稳定的而B树是不稳定查询。
  • 范围查询
    B+树只需要定位到最小的元素,然后遍历叶子节点的链表就能查询到所有的元素,而B树要每次都从上到下依次前序遍历到每一个元素。
  • 总结:
  1. 单一节点存储更多的元素,使得查询的IO次数更少。

  2. 所有查询都要查找到叶子节点,查询性能稳定。

  3. 所有叶子节点形成有序链表,便于范围查询。

1.2.3插入和删除

B+树的插入和删除和B+树类似,最重要的区别就是节点指针的调整。

注:这里只是介绍了最常用两种索引原理,其他索引将在后面穿插介绍。

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

推荐阅读更多精彩内容