MySQL InnoDB表--BTree基本資料結構
MySQL InnoDB表是索引組織表這一點應該是每一個學習MySQL的人都會首先學到的知識,這代表這表中的資料是按照主鍵順序儲存,也就是說BTree的葉子節點儲存了所有該行的資料。
我最開始是搞Oracle的,頭一次接觸MySQL的時候,預設引擎還是MyISAM。當時我看到公司建立的所有的InnoDB表都會在第一列加一個業務無關的自增主鍵,我覺得很沒有必要,問了些人這麼做的意義,得到的答案也是讓人搞不懂,其實也都沒有說到根本上,只是說這樣據說效率會更好。於是我在資料倉儲專案的建設時普遍沒有采用這種形式,大部分的表都是不指定主鍵的。
其實現在想來,最開始設計那些表的人確實是對MySQL InnoDB有研究過的,建表很講究。那麼BTree是什麼樣子的?
我畫了一個圖,但是這個圖有點問題,葉子節點應該是雙向連結串列,我只畫成了單向連結串列。這樣也可以看出來,所有的值都是存放在葉子節點中的,至於每一個頁能放多少資料,我沒有考據過,如果大家知道不妨告訴我。每每看到這個圖我都想起了我大學時代的熱血歲月,每天畫二叉樹算遍歷的成本,那會兒真是少年不知愁滋味啊。這裡的藍色方塊指的是指標,我沒有區分指向子頁的指標和指向下一個葉子頁的指標。
基本的資料結構就已經說明白了,下回有時間了更新一下插入資料和刪除資料時,如何操作。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/28207565/viewspace-1871411/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- wdcp環境innodb結構mysql資料庫表異常需要重建MySql資料庫
- 【Mysql】InnoDB 引擎中的資料頁結構MySql
- MySQL-07.InnoDB資料儲存結構MySql
- 恢復MySQL InnoDB表結構的方法MySql
- InnoDB資料頁結構
- Mysql匯出表結構、表資料MySql
- mysql儲存引擎InnoDB詳解,從底層看清InnoDB資料結構MySql儲存引擎資料結構
- mysql複製表結構和資料MySql
- MySQL 對比資料庫表結構MySql資料庫
- 《MySQL 基礎篇》十二:InnoDB 儲存引擎的資料結構MySql儲存引擎資料結構
- MySQL資料表的基本操作MySql
- 基本資料結構梳理資料結構
- MySQL-InnoDB內部結構MySql
- Mysql匯出表結構及表資料 mysqldump用法MySql
- mysql 如何複製表結構和資料MySql
- 批量修改Mysql資料庫表Innodb為MyISANMySql資料庫
- MySQL InnoDB的儲存結構總結MySql
- 七、基本資料結構(樹形結構)資料結構
- mysql 複製表資料,表結構的3種方法MySql
- MySQL系列:資料表基本操作(2)MySql
- innodb表空間儲存結構
- mysql innodb體系結構--初級MySql
- c++基本資料結構C++資料結構
- caffe的基本資料結構資料結構
- Python基本資料結構Python資料結構
- 資料結構:線性表(Python實現基本操作)資料結構Python
- EntityFramework Core筆記:表結構及資料基本操作(2)Framework筆記
- MySQL(一) 資料表資料庫的基本操作MySql資料庫
- mysql資料庫-資料結構MySql資料庫資料結構
- 資料結構c語言實現順序表基本操作資料結構C語言
- mysql完全複製一個表(結構和資料)MySql
- MySQL InnoDB系統表空間資料檔案配置MySql
- Mysql-Innodb : 從一個位元組到整個資料庫表瞭解物理儲存結構和邏輯儲存結構MySql資料庫
- MySQL InnoDB儲存引擎體系結構MySql儲存引擎
- Redis基本資料結構之ZSetRedis資料結構
- 基本資料結構演算法資料結構演算法
- 資料結構的基本概念資料結構
- Redis概述及基本資料結構Redis資料結構