3. Mysql技術(shù)內(nèi)幕-表

索引組織表

在InnoDB中,表都是根據(jù)主鍵順序組織存放的, 如果創(chuàng)建表時(shí)沒(méi)有顯示的指定主鍵,那么會(huì)按照下面

  1. 首先判斷表中是否有非空的唯一索引,如果有則取第一個(gè)定義的非空唯一索引為主鍵
  2. 如果沒(méi)有,則自動(dòng)創(chuàng)建6字節(jié)大小的指針

InnoDB邏輯存儲(chǔ)結(jié)構(gòu)

InnoDB將表空間分為段,區(qū),頁(yè)


1.png

表空間

表空間是InnoDB邏輯結(jié)構(gòu)的最高層,所有數(shù)據(jù)都放在表空間
如果開(kāi)啟innodb_file_per_table的參數(shù),表空間只保存數(shù)據(jù),索引和插入緩沖bitmap頁(yè),而undolog,插入緩沖索引頁(yè),系統(tǒng)事務(wù)信息,二次寫(xiě)緩沖等還在原來(lái)的共享表空間內(nèi)

表空間由各個(gè)端組成,常見(jiàn)的段有數(shù)據(jù)段,索引段,回滾段等,索引段為B+樹(shù)的非葉子節(jié)點(diǎn),數(shù)據(jù)段為B+樹(shù)的葉子節(jié)點(diǎn)

區(qū)

區(qū)是連續(xù)的頁(yè)組成的空間,在任何情況下區(qū)的大小都為1mb,為了保證區(qū)中頁(yè)的連續(xù)性,innodb每次從磁盤(pán)中申請(qǐng)4-5個(gè)區(qū),默認(rèn)情況下innodb的頁(yè)大小為16kb,因此一個(gè)區(qū)中有64個(gè)連續(xù)的頁(yè)

用戶啟用innodb_file_per_table,innodb會(huì)先用32個(gè)頁(yè)的碎片頁(yè)進(jìn)行存放數(shù)據(jù),使完后才會(huì)申請(qǐng)64個(gè)連續(xù)的頁(yè),這樣可以節(jié)省磁盤(pán)容量的開(kāi)銷(xiāo),解決小表或undo段

頁(yè)

頁(yè)是InnoDB磁盤(pán)管理的最小單位,每個(gè)頁(yè)大小設(shè)置完成后,只能通過(guò)mysqldump導(dǎo)入和導(dǎo)出產(chǎn)生新庫(kù)修改

  • 數(shù)據(jù)頁(yè)
  • undo頁(yè)
  • 系統(tǒng)頁(yè)
  • 事務(wù)數(shù)據(jù)頁(yè)
  • 插入緩沖位圖頁(yè)
  • 插入緩沖空閑列表頁(yè)
  • 未壓縮的二進(jìn)制大對(duì)象頁(yè)
  • 壓縮的二進(jìn)制大對(duì)象頁(yè)

innodb是面向行的,也就是數(shù)據(jù)是按照行進(jìn)行存放的,每個(gè)頁(yè)最多允許存放16kb的記錄

行記錄格式

innodb提供了compact和redundant兩種格式來(lái)存放行

compact行記錄格式

1.png
  • 首部: 一個(gè)非空變長(zhǎng)字段長(zhǎng)度列表,并且是按照列的順序逆序放置的,若長(zhǎng)度小于255字節(jié),則用1個(gè)字節(jié)表示;若大于255個(gè)字節(jié),用2字節(jié)表示
  • Null標(biāo)志位: 表示該行是有有Null值,有則是1,該部分占一個(gè)字節(jié)
  • 記錄頭信息: 固定用5個(gè)字節(jié)表示
  • 每個(gè)列實(shí)際存儲(chǔ)的數(shù)據(jù): Null不占該部分的任何空間,另外還有兩個(gè)隱藏列,事務(wù)ID列和回滾指針列,如果沒(méi)有定義主鍵,則還會(huì)增加一個(gè)rowid列

行溢出數(shù)據(jù)

mysql最大支持65532字節(jié)的varchar類(lèi)型,

Char類(lèi)型

InnoDB對(duì)Char類(lèi)型在多字節(jié)字符集類(lèi)型的存儲(chǔ)和變長(zhǎng)字符類(lèi)型相同,對(duì)于未滿長(zhǎng)度的還會(huì)填充0x20

InnoDB數(shù)據(jù)頁(yè)結(jié)構(gòu)

頁(yè)是InnoDB管理數(shù)據(jù)庫(kù)的最小磁盤(pán)單位,頁(yè)類(lèi)型為B-tree Node的頁(yè)存放的即是表中行的實(shí)際數(shù)據(jù)

頁(yè)的組成

1.png
  1. File Header


    1.png

    1.png

記錄頁(yè)的一些頭信息

  1. Page Header
    記錄數(shù)據(jù)頁(yè)的狀態(tài)信息

  2. Infimum和Supremum Record
    innodb中,每個(gè)頁(yè)都有兩個(gè)虛擬的行記錄,來(lái)限定記錄的邊界,Infimum是比該頁(yè)中任何主鍵值都小的值,Supremum是比任何可能大還要大的值


    1.png
  3. UserRecord 和FreeSpace
    UseeRecord就是實(shí)際存儲(chǔ)行記錄的內(nèi)容,
    FreeSpace就是空閑空間,是個(gè)鏈表的數(shù)據(jù)結(jié)構(gòu),一條記錄刪除后會(huì)放到空閑鏈表中

  4. Page Directory
    存放了記錄的相對(duì)位置,不是偏移量,在InnoDB中是一個(gè)槽中可能會(huì)保存多個(gè)記錄
    B+數(shù)索引本身不能查到具體的一條記錄,而是查到記錄所在的頁(yè),然后數(shù)據(jù)庫(kù)把頁(yè)載入到內(nèi)存中,通過(guò)pagedirectory進(jìn)行二叉查找

  5. File Trailer
    檢測(cè)頁(yè)是否已經(jīng)完整地寫(xiě)入磁盤(pán)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子俘闯,更是在濱河造成了極大的恐慌甸各,老刑警劉巖,帶你破解...
    沈念sama閱讀 207,113評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件卧须,死亡現(xiàn)場(chǎng)離奇詭異另绩,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)花嘶,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門(mén)笋籽,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人椭员,你說(shuō)我怎么就攤上這事车海。” “怎么了隘击?”我有些...
    開(kāi)封第一講書(shū)人閱讀 153,340評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵侍芝,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我埋同,道長(zhǎng)州叠,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,449評(píng)論 1 279
  • 正文 為了忘掉前任凶赁,我火速辦了婚禮咧栗,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘虱肄。我一直安慰自己致板,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評(píng)論 5 374
  • 文/花漫 我一把揭開(kāi)白布咏窿。 她就那樣靜靜地躺著斟或,像睡著了一般。 火紅的嫁衣襯著肌膚如雪集嵌。 梳的紋絲不亂的頭發(fā)上萝挤,一...
    開(kāi)封第一講書(shū)人閱讀 49,166評(píng)論 1 284
  • 那天御毅,我揣著相機(jī)與錄音,去河邊找鬼平斩。 笑死亚享,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的绘面。 我是一名探鬼主播欺税,決...
    沈念sama閱讀 38,442評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼揭璃!你這毒婦竟也來(lái)了晚凿?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,105評(píng)論 0 261
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤瘦馍,失蹤者是張志新(化名)和其女友劉穎歼秽,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體情组,經(jīng)...
    沈念sama閱讀 43,601評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡燥筷,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了院崇。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片肆氓。...
    茶點(diǎn)故事閱讀 38,161評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖底瓣,靈堂內(nèi)的尸體忽然破棺而出谢揪,到底是詐尸還是另有隱情,我是刑警寧澤捐凭,帶...
    沈念sama閱讀 33,792評(píng)論 4 323
  • 正文 年R本政府宣布拨扶,位于F島的核電站,受9級(jí)特大地震影響茁肠,放射性物質(zhì)發(fā)生泄漏患民。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評(píng)論 3 307
  • 文/蒙蒙 一垦梆、第九天 我趴在偏房一處隱蔽的房頂上張望匹颤。 院中可真熱鬧,春花似錦奶赔、人聲如沸惋嚎。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,352評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至鼻百,卻和暖如春绞旅,著一層夾襖步出監(jiān)牢的瞬間摆尝,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,584評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工因悲, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留堕汞,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,618評(píng)論 2 355
  • 正文 我出身青樓晃琳,卻偏偏與公主長(zhǎng)得像讯检,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子卫旱,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評(píng)論 2 344