MySQL VARCHAR 列的最大长度是多少?

mysqlmysqli database

实际上,VARCHAR 数据类型以单字节和多字节字符形式存储可变长度字符数据。此数据类型的语法为 VARCHAR(n),其中 n 是最大字符数,必须在创建表时指定。在 MySQL 5.03 之前,n 的值可以在 0 到 255 的范围内,但在 MySQL 5.03 及之后,该值可以在 0 到 65,535 的范围内。

VARCHAR 中存储的最大字符数取决于最大行大小和使用的字符集。如果我们使用 ASCII 字符集,那么它可以存储 65,535 个字符,因为 ASCII 每个字符使用 1 个字节。另一方面,如果我们使用 utf8 字符集,那么字符限制将是 21,844,因为 utf8 每个字符使用 3 个字节。最大行大小限制为 65,535 字节,这意味着包括所有列在内,行大小不得超过 65,535 字节。

示例

mysql> Create Table var_test(FName Varchar(32765) NOT NULL, LName Varchar(32766)
       NOT NULL);
       Query OK, 0 rows affected (0.25 sec)

上述查询创建了一个包含两列的表,FName Varchar(32765) 和 LName Varchar(32766)。因此,总长度为 32765+2+32766+2=65535(每列使用 2 个字节来存储长度)。

mysql> Create Table var_test1(FName varchar(32766) NOT NULL, LName Varchar(32766)
       NOT NULL);
       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

现在,如果将长度增加 1 个字节,MySQL 将返回错误,如上面的查询所示。


相关文章