VARCHAR数据类型将可变长度字符数据存储在单字节和多字节字符中。此数据类型的语法为VARCHAR(n),其中n是最大字符数,并且必须在创建表时指定。在MySQL 5.03之前,n的值可以在0到255之间,但是在MySQL 5.03之前和之后,n的值可以在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);
上面的查询创建了一个包含两列的表,即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就会返回一个错误,如上面的查询所示。
热门文章
- 动物疫苗工艺 动物疫苗工艺流程
- 动物打预防针去哪里打针好点(给动物打疫苗的官方部门)
- 「12月21日」最高速度22.9M/S,2024年SSR/Clash/V2ray/Shadowrocket每天更新免费机场订阅链接
- 驱虫给猫多少钱(驱虫猫多少钱一次)
- 猫给抓了出一点点血要紧吗我和酒精擦了(猫抓了一下出了点血用酒精消毒可以吗)
- C++编程——C++对象模型和this指针
- 人用针剂和兽用针剂(人用针剂和兽用针剂哪个好)
- vue+Echarts绘制动态折线图
- 「11月20日」最高速度22.2M/S,2024年Clash/SSR/V2ray/Shadowrocket每天更新免费机场订阅链接
- 「12月11日」最高速度20M/S,2024年Shadowrocket/SSR/Clash/V2ray每天更新免费机场订阅链接