MySQL InnoDB表--BTree基本資料結構

來源:互聯網
上載者:User

標籤:

    MySQL InnoDB表是索引組織表這一點應該是每一個學習MySQL的人都會首先學到的知識,這代表這表中的資料是按照主鍵順序儲存,也就是說BTree的葉子節點儲存了所有該行的資料。

    我最開始是搞Oracle的,頭一次接觸MySQL的時候,預設引擎還是MyISAM。當時我看到公司建立的所有的InnoDB表都會在第一列加一個業務無關的自增主鍵,我覺得很沒有必要,問了些人這麼做的意義,得到的答案也是讓人搞不懂,其實也都沒有說到根本上,只是說這樣據說效率會更好。於是我在資料倉儲項目的建設時普遍沒有採用這種形式,大部分的表都是不指定主鍵的。

    其實現在想來,最開始設計那些表的人確實是對MySQL InnoDB有研究過的,建表很講究。那麼BTree是什麼樣子的?

    

    我畫了一個圖,但是這個圖有點問題,葉子節點應該是雙向鏈表,我只畫成了單向鏈表。這樣也可以看出來,所有的值都是存放在葉子節點中的,至於每一個頁能放多少資料,我沒有考據過,如果大家知道不妨告訴我。每每看到這個圖我都想起了我大學時代的熱血歲月,每天畫二叉樹算遍曆的成本,那會兒真是少年不知愁滋味啊。這裡的藍色方塊指的是指標,我沒有區分指向子頁的指標和指向下一個葉子頁的指標。

    基本的資料結構就已經說明白了,下回有時間了更新一下插入資料和刪除資料時,如何操作。

MySQL InnoDB表--BTree基本資料結構

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.