在 MySQL 中,char 類型用于存儲(chǔ)固定長(zhǎng)度的字符串,字符集為 Latin1,每個(gè)字符占據(jù)一個(gè)字節(jié)的存儲(chǔ)空間。
CREATE TABLE `user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` char(10) NOT NULL, `age` tinyint(4) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB DEFAULT CHARSET=latin1;
在上面的代碼中,定義了一個(gè) user 表,其中 name 字段的類型為 char(10),表示該字段最多存儲(chǔ) 10 個(gè)字符的字符串。由于每個(gè)字符占據(jù) 1 個(gè)字節(jié)的存儲(chǔ)空間,因此 name 字段實(shí)際占據(jù)的存儲(chǔ)空間為 10 個(gè)字節(jié)。
需要注意的是,char 類型的字符串是固定長(zhǎng)度的,若存儲(chǔ)的字符串中字符數(shù)小于指定的長(zhǎng)度,那么剩余的存儲(chǔ)空間將被填充為 ASCII 碼為 0 的字符。例如,若插入一條 name 字段為 'Tom' 的記錄,則 MySQL 會(huì)在 'Tom' 后面填充 7 個(gè) ASCII 碼為 0 的字符,以滿足 char(10) 的長(zhǎng)度要求。
綜上所述,char 類型在 MySQL 中占據(jù)固定長(zhǎng)度的存儲(chǔ)空間,每個(gè)字符占據(jù) 1 個(gè)字節(jié)。