1. 程式人生 > >Mysql 裡CHAR和VARCHAR的最大長度及一些注意事項

Mysql 裡CHAR和VARCHAR的最大長度及一些注意事項

(未完未完全驗證,有空再驗證)

先寫出結論:

Mysql 5中

非空CHAR的最大總長度是255【位元組】;非空VARCHAR的最大總長度是65533【位元組】。

可空CHAR的最大總長度是254【位元組】;可空VARCHAR的最大總長度是65532【位元組】。

原因:非空標記需要佔據一個位元組,VARCHAR超過255需要用2個位元組標記欄位長度,不超過255用1個位元組標記欄位長度.

注意上邊是 【位元組】,不是【字元】。但mysql5欄位定義時,是定義的【字元】數。比如varchar(10),你僅能存入10個英文字母或者漢字,儘管一個字元可能佔多個位元組。

一個字元可能佔用多個位元組,這由編碼和存放的字元決定。比如UTF8(一種變長的unicode編碼)中,

一般一個漢字佔據3個位元組,一個英文字母佔據一個位元組。

所以,在UTF8的環境下,不允許定義 VARCHAR(65535),因為這遠遠超出了65535個位元組的限制。

以下是MYSQL 官網上的說明:

CHARVARCHAR型別類似,但它們儲存和檢索的方式不同。它們的最大長度和是否尾部空格被保留等方面也不同。在儲存或檢索過程中不進行大小寫轉換。

CHARVARCHAR型別宣告的長度表示你想要儲存的最大字元數。例如,CHAR(30)可以佔用30個字元。

CHAR列的長度固定為建立表時宣告的長度。長度可以為從0255的任何值。當儲存CHAR值時,在它們的右邊填充空格以達到指定的長度。當檢索到CHAR

值時,尾部的空格被刪除掉。在儲存或檢索過程中不進行大小寫轉換。

VARCHAR列中的值為可變長字串。長度可以指定為065,535之間的值。(VARCHAR的最大有效長度由最大行大小和使用的字符集確定。整體最大長度是65,532位元組)

CHAR對比,VARCHAR值儲存時只儲存需要的字元數,另加一個位元組來記錄長度(如果列宣告的長度超過255,則使用兩個位元組)

VARCHAR值儲存時不進行填充。當值儲存和檢索時尾部的空格仍保留,符合標準SQL

如果分配給CHARVARCHAR列的值超過列的最大長度,則對值進行裁剪以使其適合。如果被裁掉的字元不是空格,則會產生一條警告。如果裁剪非空格字元,則會造成錯誤(

而不是警告)並通過使用嚴格SQL模式禁用值的插入。參見5.3.2節,“SQL伺服器模式”

下面的表顯示了將各種字串值儲存到CHAR(4)VARCHAR(4)列後的結果,說明了CHARVARCHAR之間的差別:

CHAR(4)

儲存需求

VARCHAR(4)

儲存需求

''

<span ''

4個位元組

''

1個位元組

'ab'

<span 'ab'

4個位元組

'ab '

3個位元組

'abcd'

'abcd'

4個位元組

'abcd'

5個位元組

'abcdefgh'

'abcd'

4個位元組

'abcd'

5個位元組

請注意上表中最後一行的值只適用不使用嚴格模式時;如果MySQL執行在嚴格模式,超過列長度不的值儲存,並且會出現錯誤。

CHAR(4)VARCHAR(4)列檢索的值並不總是相同,因為檢索時從CHAR列刪除了尾部的空格。通過下面的例子說明該差別:

mysql> CREATE TABLE vc (v VARCHAR(4), c CHAR(4));
Query OK, 0 rows affected (0.02 sec)
mysql> INSERT INTO vc VALUES ('ab  ', 'ab  ');
Query OK, 1 row affected (0.00 sec)
mysql> SELECT CONCAT(v, '+'), CONCAT(c, '+') FROM vc;
+----------------+----------------+
| CONCAT(v, '+') | CONCAT(c, '+') |
+----------------+----------------+
| ab  +          | ab+            |
+----------------+----------------+
1 row in set (0.00 sec)

根據分配給列的字符集校對規則對CHARVARCHAR列中的值進行排序和比較。

請注意所有MySQL校對規則屬於PADSPACE類。這說明在MySQL中的所有CHARVARCHAR值比較時不需要考慮任何尾部空格。

參考: