2019-04-17InnoDB記錄存儲(chǔ)結(jié)構(gòu)

4種不同類(lèi)型的行格式,分別是Compact、Redundant、Dynamic和Compressed行格式


1 compact

如果表中沒(méi)有允許存儲(chǔ)?NULL?的列,則?NULL值列表?也不存在了,否則將每個(gè)允許存儲(chǔ)NULL的列對(duì)應(yīng)一個(gè)二進(jìn)制位,二進(jìn)制位按照列的順序逆序排列,二進(jìn)制位表示的意義如下:

二進(jìn)制位的值為1時(shí),代表該列的值為NULL。

二進(jìn)制位的值為0時(shí),代表該列的值不為NULL。

因?yàn)楸韗ecord_format_demo有3個(gè)值允許為NULL的列,所以這3個(gè)列和二進(jìn)制位的對(duì)應(yīng)關(guān)系就是這樣:


二進(jìn)制位按照列的順序逆序排列,所以第一個(gè)列c1和最后一個(gè)二進(jìn)制位對(duì)應(yīng)。

記錄的真實(shí)數(shù)據(jù)

對(duì)于record_format_demo表來(lái)說(shuō),記錄的真實(shí)數(shù)據(jù)除了c1、c2、c3、c4這幾個(gè)我們自己定義的列的數(shù)據(jù)以外,MySQL會(huì)為每個(gè)記錄默認(rèn)的添加一些列(也稱(chēng)為隱藏列),具體的列如下:

列名是否必須占用空間描述

小貼士: 實(shí)際上這幾個(gè)列的真正名稱(chēng)其實(shí)是:DB_ROW_ID、DB_TRX_ID、DB_ROLL_PTR,我們?yōu)榱嗣烙^才寫(xiě)成了row_id、transaction_id和roll_pointer。

頁(yè)是MySQL中磁盤(pán)和內(nèi)存交互的基本單位,也是MySQL是管理存儲(chǔ)空間的基本單位。

指定和修改行格式的語(yǔ)法如下:

CREATE TABLE 表名 (列的信息) ROW_FORMAT=行格式名稱(chēng)

ALTER TABLE 表名 ROW_FORMAT=行格式名稱(chēng)

InnoDB目前定義了4種行格式

COMPACT行格式

具體組成如圖:

Redundant行格式

具體組成如圖:

Dynamic和Compressed行格式

這兩種行格式類(lèi)似于COMPACT行格式,只不過(guò)在處理行溢出數(shù)據(jù)時(shí)有點(diǎn)兒分歧,它們不會(huì)在記錄的真實(shí)數(shù)據(jù)處存儲(chǔ)字符串的前768個(gè)字節(jié),而是把所有的字節(jié)都存儲(chǔ)到其他頁(yè)面中,只在記錄的真實(shí)數(shù)據(jù)處存儲(chǔ)其他頁(yè)面的地址。

另外,Compressed行格式會(huì)采用壓縮算法對(duì)頁(yè)面進(jìn)行壓縮。

一個(gè)頁(yè)一般是16KB,當(dāng)記錄中的數(shù)據(jù)太多,當(dāng)前頁(yè)放不下的時(shí)候,會(huì)把多余的數(shù)據(jù)存儲(chǔ)到其他頁(yè)中,這種現(xiàn)象稱(chēng)為行溢出。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容