MySQL定長(zhǎng)字符串的含義
MySQL定長(zhǎng)字符串是指在創(chuàng)建表的時(shí)候指定該字段的長(zhǎng)度,無(wú)論數(shù)據(jù)實(shí)際長(zhǎng)度如何,該字段所占用的空間都是固定的。
如何創(chuàng)建MySQL定長(zhǎng)字符串
創(chuàng)建MySQL定長(zhǎng)字符串的語(yǔ)法格式為:VARCHAR(length)或CHAR(length),其中,VARCHAR表示變長(zhǎng)字符串,需要手動(dòng)設(shè)定字符串的長(zhǎng)度;CHAR表示定長(zhǎng)字符串,字符串長(zhǎng)度必須是指定的固定長(zhǎng)度。
例如:
CREATE TABLE `example` (
`name` VARCHAR(10) NOT NULL,
`age` CHAR(3) NOT NULL
);
MySQL定長(zhǎng)字符串的優(yōu)缺點(diǎn)
優(yōu)點(diǎn):由于字段長(zhǎng)度是固定的,所以MySQL定長(zhǎng)字符串不會(huì)出現(xiàn)變長(zhǎng)字符串占用過(guò)多空間的問(wèn)題,因此在數(shù)據(jù)的存入和查找時(shí)速度更快。
缺點(diǎn):固定長(zhǎng)度的字符串很容易浪費(fèi)空間,因?yàn)槿绻侄螌?shí)際內(nèi)容長(zhǎng)度小于字段定義的長(zhǎng)度,則該字段占用的空間將浪費(fèi)掉;
如何選擇MySQL定長(zhǎng)字符串
對(duì)于長(zhǎng)度固定不變的內(nèi)容,如身份證號(hào)、電話號(hào)碼等,建議使用MySQL定長(zhǎng)字符串;對(duì)于長(zhǎng)度變化的內(nèi)容,如用戶名、地址等,建議使用MySQL變長(zhǎng)字符串。
在具體使用時(shí),根據(jù)數(shù)據(jù)類型和數(shù)據(jù)長(zhǎng)度來(lái)選擇字符類型。