mysql選擇B+樹(shù)作為索引的原因

從最初的問(wèn)題出發(fā),mysql是用來(lái)存儲(chǔ)&&查詢數(shù)據(jù)的越锈,索引是用來(lái)加速數(shù)據(jù)查詢過(guò)程的产园。如果讓我們?cè)O(shè)計(jì)一個(gè)數(shù)據(jù)存儲(chǔ)系統(tǒng),我們?nèi)绾稳?shí)現(xiàn)滔驶?

1--數(shù)組 or 鏈表

最簡(jiǎn)單的想法是直接用數(shù)組存儲(chǔ)所需的數(shù)據(jù),但是會(huì)存在插入新元素會(huì)導(dǎo)致大量元素后移的操作卿闹,費(fèi)時(shí)費(fèi)力揭糕;并且查找元素,數(shù)組和鏈表都需要粗暴的遍歷锻霎,不可戎恰;由此可想到二叉搜索樹(shù)

2--二叉搜索樹(shù)? BST

二叉搜索樹(shù)旋恼,又叫二叉排序樹(shù)吏口、二叉查找樹(shù),極端情況下會(huì)退化為鏈表、樹(shù)高度不可控产徊,pass

3--平衡二叉樹(shù)AVL

AVL是最早發(fā)明的自平衡二叉搜索樹(shù):

1.本身首先是一棵二叉搜索樹(shù)昂勒。

2.帶有平衡條件:每個(gè)結(jié)點(diǎn)的左右子樹(shù)的高度之差的絕對(duì)值(平衡因子)最多為1。

也就是說(shuō)舟铜,AVL樹(shù)戈盈,本質(zhì)上是帶了平衡功能的二叉查找樹(shù)(二叉排序樹(shù),二叉搜索樹(shù))谆刨。通過(guò)左旋和右旋實(shí)現(xiàn)左右子樹(shù)深度差不超過(guò)1塘娶,避免了二叉樹(shù)的極端情況的出現(xiàn)。

為什么不使用AVL作為索引:浪費(fèi)空間痊夭,具體原因如下:

Innodb存儲(chǔ)引擎的存儲(chǔ)單位是 頁(yè)(page)刁岸,1頁(yè)的大小是16kb,1頁(yè)就是樹(shù)的1個(gè)結(jié)點(diǎn)她我,而每查詢一次結(jié)點(diǎn)就要進(jìn)行一次IO操作虹曙;如果使用平衡二叉樹(shù),一個(gè)結(jié)點(diǎn)存儲(chǔ)的信息大小遠(yuǎn)達(dá)不到16kb鸦难,太浪費(fèi)空間根吁;AVL樹(shù)存在的最大問(wèn)題就是空間利用不足,浪費(fèi)了大量空間合蔽,數(shù)據(jù)量大的時(shí)候就會(huì)成為一顆瘦高的樹(shù)击敌,樹(shù)越高,IO次數(shù)越多拴事。

4--B樹(shù)(B-樹(shù)沃斤、多路平衡查找樹(shù))

由AVL樹(shù)的缺點(diǎn)可想到改進(jìn)方向:樹(shù)越矮胖越好,這樣IO次數(shù)就少刃宵,但是為什么用B+樹(shù)而不是用B樹(shù)衡瓶?是因?yàn)锽+樹(shù)對(duì)B樹(shù)進(jìn)行了改進(jìn):

1)根節(jié)點(diǎn)、枝結(jié)點(diǎn)不存儲(chǔ)數(shù)據(jù)牲证,只有葉子結(jié)點(diǎn)存儲(chǔ)數(shù)據(jù)哮针,這樣每個(gè)結(jié)點(diǎn)可以保存更多的關(guān)鍵字,一次磁盤(pán)IO可以加載更多的關(guān)鍵字坦袍;

2)掃表能力更強(qiáng):葉子結(jié)點(diǎn)存儲(chǔ)了相鄰葉子結(jié)點(diǎn)的指針形成了鏈表十厢,葉子結(jié)點(diǎn)數(shù)據(jù)天然有序,直接遍歷結(jié)點(diǎn)即可獲取所有數(shù)據(jù)捂齐,無(wú)需像B樹(shù)一樣遍歷整棵樹(shù)蛮放;

3)效率穩(wěn)定,B樹(shù)每次獲取數(shù)據(jù)的深度不一定奠宜,而B(niǎo)+樹(shù)每次都需要到葉子結(jié)點(diǎn)包颁,效率和時(shí)間消耗穩(wěn)定可預(yù)估瞻想;

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市娩嚼,隨后出現(xiàn)的幾起案子蘑险,更是在濱河造成了極大的恐慌,老刑警劉巖待锈,帶你破解...
    沈念sama閱讀 222,183評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件漠其,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡竿音,警方通過(guò)查閱死者的電腦和手機(jī)和屎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,850評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)春瞬,“玉大人柴信,你說(shuō)我怎么就攤上這事】砥” “怎么了随常?”我有些...
    開(kāi)封第一講書(shū)人閱讀 168,766評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)萄涯。 經(jīng)常有香客問(wèn)我绪氛,道長(zhǎng),這世上最難降的妖魔是什么涝影? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,854評(píng)論 1 299
  • 正文 為了忘掉前任枣察,我火速辦了婚禮,結(jié)果婚禮上燃逻,老公的妹妹穿的比我還像新娘序目。我一直安慰自己,他們只是感情好伯襟,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,871評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布猿涨。 她就那樣靜靜地躺著,像睡著了一般姆怪。 火紅的嫁衣襯著肌膚如雪叛赚。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 52,457評(píng)論 1 311
  • 那天稽揭,我揣著相機(jī)與錄音俺附,去河邊找鬼。 笑死淀衣,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的召调。 我是一名探鬼主播膨桥,決...
    沈念sama閱讀 40,999評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼蛮浑,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了只嚣?” 一聲冷哼從身側(cè)響起沮稚,我...
    開(kāi)封第一講書(shū)人閱讀 39,914評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎册舞,沒(méi)想到半個(gè)月后蕴掏,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,465評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡调鲸,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,543評(píng)論 3 342
  • 正文 我和宋清朗相戀三年盛杰,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片藐石。...
    茶點(diǎn)故事閱讀 40,675評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡即供,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出于微,到底是詐尸還是另有隱情逗嫡,我是刑警寧澤,帶...
    沈念sama閱讀 36,354評(píng)論 5 351
  • 正文 年R本政府宣布株依,位于F島的核電站驱证,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏恋腕。R本人自食惡果不足惜抹锄,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,029評(píng)論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望吗坚。 院中可真熱鬧祈远,春花似錦、人聲如沸商源。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,514評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)牡彻。三九已至扫沼,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間庄吼,已是汗流浹背缎除。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,616評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留总寻,地道東北人器罐。 一個(gè)月前我還...
    沈念sama閱讀 49,091評(píng)論 3 378
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像渐行,于是被迫代替她去往敵國(guó)和親轰坊。 傳聞我的和親對(duì)象是個(gè)殘疾皇子铸董,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,685評(píng)論 2 360

推薦閱讀更多精彩內(nèi)容