Mysql varchar大小長度問題介紹
更新時間:2011年10月24日 23:55:26 作者:
如果被 varchar 超過上述的 b 規(guī)則,被強轉成 text 類型,則每個字段占用定義長度為 11 字節(jié),當然這已經不是 varchar 了
4.0版本以下,varchar(20),指的是20字節(jié),如果存放UTF8漢字時,只能存6個(每個漢字3字節(jié))
5.0版本以上,varchar(20),指的是20字符,無論存放的是數字、字母還是UTF8漢字(每個漢字3字節(jié)),都可以存放20個,最大大小是65532字節(jié)
Mysql4中最大也不過是20個字節(jié),但是Mysql5根據編碼不同,存儲大小也不同。
1、限制規(guī)則
字段的限制在字段定義的時候有以下規(guī)則:
a) 存儲限制
varchar 字段是將實際內容單獨存儲在聚簇索引之外,內容開頭用1到2個字節(jié)表示實際長度(長度超過255時需要2個字節(jié)),因此最大長度不能超過65535。
b) 編碼長度限制
字符類型若為gbk,每個字符最多占2個字節(jié),最大長度不能超過32766;
字符類型若為utf8,每個字符最多占3個字節(jié),最大長度不能超過21845。
若定義的時候超過上述限制,則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的原因是實際行存儲從第二個字節(jié)開始';
減2的原因是varchar頭部的2個字節(jié)表示長度;
除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個字節(jié);
減30*3的原因是char(30)占用90個字節(jié),編碼是utf8。
如果被 varchar 超過上述的 b 規(guī)則,被強轉成 text 類型,則每個字段占用定義長度為 11 字節(jié),當然這已經不是“ varchar ”了。
5.0版本以上,varchar(20),指的是20字符,無論存放的是數字、字母還是UTF8漢字(每個漢字3字節(jié)),都可以存放20個,最大大小是65532字節(jié)
Mysql4中最大也不過是20個字節(jié),但是Mysql5根據編碼不同,存儲大小也不同。
1、限制規(guī)則
字段的限制在字段定義的時候有以下規(guī)則:
a) 存儲限制
varchar 字段是將實際內容單獨存儲在聚簇索引之外,內容開頭用1到2個字節(jié)表示實際長度(長度超過255時需要2個字節(jié)),因此最大長度不能超過65535。
b) 編碼長度限制
字符類型若為gbk,每個字符最多占2個字節(jié),最大長度不能超過32766;
字符類型若為utf8,每個字符最多占3個字節(jié),最大長度不能超過21845。
若定義的時候超過上述限制,則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的原因是實際行存儲從第二個字節(jié)開始';
減2的原因是varchar頭部的2個字節(jié)表示長度;
除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個字節(jié);
減30*3的原因是char(30)占用90個字節(jié),編碼是utf8。
如果被 varchar 超過上述的 b 規(guī)則,被強轉成 text 類型,則每個字段占用定義長度為 11 字節(jié),當然這已經不是“ varchar ”了。
相關文章
Mysql中FIND_IN_SET()和IN區(qū)別簡析
這篇文章主要介紹了Mysql中FIND_IN_SET()和IN區(qū)別簡析,設計實例代碼,具有一定參考價值。需要的朋友可以了解。2017-10-10mysql正確刪除數據的方法(drop,delete,truncate)
這篇文章主要給大家介紹了關于mysql正確刪除數據的相關資料,DELETE語句是MySQL中最常用的刪除數據的方式之一,但也有幾種其他方法來實現,需要的朋友可以參考下2023-10-10Window下如何恢復被刪除的Mysql8.0.17 Root賬戶及密碼
這篇文章主要介紹了Window下如何恢復被刪除的Mysql8.0.17 Root賬戶及密碼,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2020-02-02mysql中Table is read only的解決方法小結
本文章總結了關于在linux與windows中 mysql出現Table is read only解決辦法總結,有需要的朋友可參考一下2013-01-01SQL的substring_index()用法實例(MySQL字符串截取)
substring_index?(字符串,分隔符,序號),主要作用是用于截取目標字符串,下面這篇文章主要給大家介紹了關于SQL中substring_index()用法(MySQL字符串截取)的相關資料,需要的朋友可以參考下2023-01-01