1. 程式人生 > >Mysql varchar型別長度計算

Mysql varchar型別長度計算

建立表時,varchar欄位的長度最大能設定多少?

1,跟字符集GBK,UTF8等有關
2,跟當前表所有列總長度有關


檢視char,varchar字元數,位元組長度,十六進位制儲存
select class,char_length(class),length(class),hex(class) from classes;




1、限制規則

欄位的限制在欄位定義的時候有以下規則:
a)儲存限制
    varchar 欄位是將實際內容單獨儲存在聚簇索引之外,內容開頭用1到2個位元組表示實際長度(長度超過255時需要2個位元組),因此最大長度不能超過65535。


b)編碼長度限制
    字元型別若為gbk,每個字元最多佔2個位元組,最大長度不能超過32766;
    字元型別若為utf8,每個字元最多佔3個位元組,最大長度不能超過21845。
    對於英文比較多的論壇 ,使用GBK則每個字元佔用2個位元組,而使用UTF-8英文卻只佔一個位元組。
    若定義的時候超過上述限制,則varchar欄位會被強行轉為text型別,併產生warning。


c)行長度限制
    導致實際應用中varchar長度限制的是一個行定義的長度。 MySQL要求一個行的定義長度不能超過65535。若定義的表長度超過這個值,則提示
    ERROR 1118 (42000): Row size too large. The maximum row size for the used table type, not counting BLOBs, is 65535. You have to change some columns to TEXT or BLOBs。



2、計算例子
a)若一個表只有一個varchar型別,如定義為create table t4(c varchar(N)) charset=gbk;
則此處N的最大值為(65535-1-2)/2 = 32766

減1的原因是實際行儲存從第二個位元組開始';
減2的原因是varchar頭部的2個位元組表示長度;
除2的原因是字元編碼是gbk。


b)若一個表定義為create table t4(c int, c2 char(30), c3 varchar(N)) charset=utf8;
則此處N的最大值為 (65535-1-2-4-30*3)/3 = 21812
減1和減2與上例相同;
減4的原因是int型別的c佔4個位元組;
減30*3的原因是char(30)佔用90個位元組,編碼是utf8。


如果被varchar超過上述的b規則,被強轉成text型別,則每個欄位佔用定義長度為11位元組,當然這已經不是“varchar”了。