在MySQL5.0.3及以上的版本中,varchar數據類型的長度支持到了65535,也就是說可以存放65532個字節的數據,起始位和結束位占去了3個字節,也就是說,在5.0.3以下版本中需要使用固定的TEXT或BLOB格式存放的數據可以在高版本中使用可變長的varchar來存放,這樣就能有效的減少數據庫文件的大小。 1、限制規則
MySQL數據庫教程的varchar類型在5.0.3以下的版本中的最大長度限制為255,其數據范圍可以是0~255。
在MySQL5.0.3及以上的版本中,varchar數據類型的長度支持到了65535,也就是說可以存放65532個字節的數據,起始位和結束位占去了3個字節,也就是說,在5.0.3以下版本中需要使用固定的TEXT或BLOB格式存放的數據可以在高版本中使用可變長的varchar來存放,這樣就能有效的減少數據庫文件的大小。
1、限制規則
字段的限制在字段定義的時候有以下規則:
a)存儲限制
varchar字段是將實際內容單獨存儲在聚簇索引之外,內容開頭用1到2個字節表示實際長度(長度超過255時需要2個字節),因此最大長度不能超過65535。
b)編碼長度限制
字符類型若為gbk,每個字符最多占2個字節,最大長度不能超過32766;
字符類型若為utf8,每個字符最多占3個字節,最大長度不能超過21845。
若定義的時候超過上述限制,則varchar字段會被強行轉為text類型,並產生warning。
c)行長度限制
導致實際應用中varchar長度限制的是一個行定義的長度。MySQL要求一個行的定義長度不能超過65535。若定義的表長度超過這個值,則提示ERROR1118(42000):Rowsizetoolarge.Themaximumrowsizefortheusedtabletype,notcountingBLOBs,is65535.YouhavetochangesomecolumnstoTEXTorBLOBs。
2、計算例子
舉兩個例說明一下實際長度的計算。
a)若一個表只有一個varchar類型,如定義為createtablet4(cvarchar(N))charset=gbk;則此處N的最大值為(65535-1-2)/2=32766。
減1的原因是實際行存儲從第二個字節開始';
減2的原因是varchar頭部的2個字節表示長度;
除2的原因是字符編碼是gbk。
b)若一個表定義為createtablet4(cint,c2char(30),c3varchar(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”了。
關於MySQL數據庫中varchar的限制規則的知識就介紹到這裡了,希望本次的介紹能夠對您有所收獲