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)為行溢出。