
实际上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个字节来存储长度)。
序列猴子开放平台
具有长序列、多模态、单模型、大数据等特点的超大规模语言模型
0 查看详情
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 将返回一个错误,如上面的查询所示。
以上就是MySQL VARCHAR 列的最大长度是多少?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/238861.html
微信扫一扫
支付宝扫一扫