MySQL建表字段长度的限制、汉字和字母占字节数 您所在的位置:网站首页 数据表字段个数怎么设置 MySQL建表字段长度的限制、汉字和字母占字节数

MySQL建表字段长度的限制、汉字和字母占字节数

2024-06-30 04:12| 来源: 网络整理| 查看: 265

varchar(N),N指的是最大字符数,不是字节数。

记住:

(1)MySQL要求一个行的定义长度不能超过65535。

(2)单个字段如果大于65535,则转换为TEXT 。

(3)单行最大限制为65535,这里不包括TEXT、BLOB。

(4)utf8: 1character=3bytes, 1汉字=1character 也就是说一个字段定义成 varchar(200),则它可以存储200个汉字或者200个字母。(5)gbk: 1character=2bytes,1汉字=1character 也就是说一个字段定义成 varchar(200),则它可以存储200个汉字或者200个字母。

在MySQL建表时,遇到一个奇怪的现象:

    root@localhost : test 10:30:54>CREATE TABLE tb_test (   -> recordid varchar(32) NOT NULL,   -> areaShow varchar(10000) DEFAULT NULL,   -> areaShow1 varchar(10000) DEFAULT NULL,   -> areaShow2 varchar(10000) DEFAULT NULL,   -> PRIMARY KEY (recordid)   -> ) ENGINE=INNODB DEFAULT CHARSET=utf8;   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   报错       root@localhost : test 10:31:01>CREATE TABLE tb_test (   -> recordid varchar(32) NOT NULL,   -> areaShow varchar(30000) DEFAULT NULL,   -> areaShow1 varchar(30000) DEFAULT NULL,   -> areaShow2 varchar(30000) DEFAULT NULL,   -> PRIMARY KEY (recordid)   -> ) ENGINE=INNODB DEFAULT CHARSET=utf8;   Query OK, 0 rows affected, 3 warnings (0.26 sec)   可以建立,只是类型被转换了。       root@localhost : test 10:31:14>show warnings;   +-------+------+----------------------------------------------------+   | Level | Code | Message |   +-------+------+----------------------------------------------------+   | Note | 1246 | Converting column 'areaShow' from VARCHAR to TEXT |   | Note | 1246 | Converting column 'areaShow1' from VARCHAR to TEXT |   | Note | 1246 | Converting column 'areaShow2' from VARCHAR to TEXT |   +-------+------+----------------------------------------------------+   3 rows in set (0.00 sec)  

 

疑问:

为什么字段小(10000)的反而报错,而大(30000)的则可以建立。为什么小的不能直接转换呢?

解决:

MySQL要求一个行的定义长度不能超过65535。

(1)单个字段如果大于65535,则转换为TEXT 。

(2)单行最大限制为65535,这里不包括TEXT、BLOB。

按照上面总结的限制,来解释出现的现象:

第一个情况是: 单个字段长度:varchar(10000) ,字节数:10000*3(utf8)+(1 or 2) = 30000 ,小于65535,可以建立。 单行记录长度:varchar(10000)*3,字节数:30000*3(utf8)+(1 or 2) = 90000,大于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  

第二个情况是: 单个字段长度:varchar(30000) ,字节数:30000*3+(1 or 2) = 90000 , 大于65535,需要转换成TEXT,才可以建立。所以报warnings。 单行记录长度:varchar(30000)*3,因为每个字段都被转换成了TEXT,而TEXT没有限制,所以可以建立表。

    root@localhost : test 10:31:14>show warnings;   +-------+------+----------------------------------------------------+   | Level | Code | Message |   +-------+------+----------------------------------------------------+   | Note | 1246 | Converting column 'areaShow' from VARCHAR to TEXT |   | Note | 1246 | Converting column 'areaShow1' from VARCHAR to TEXT |   | Note | 1246 | Converting column 'areaShow2' from VARCHAR to TEXT |   +-------+------+----------------------------------------------------+  

用了这么久的MySQL,这个基本的建表限制都还不知道,惭愧啊。。

 

原因如下:

  被问到一个问题:MySQL中varchar最大长度是多少?这不是一个固定的数字。本文简要说明一下限制规则。

1、限制规则

字段的限制在字段定义的时候有以下规则:

a)  存储限制

       varchar 字段是将实际内容单独存储在聚簇索引之外,内容开头用1到2个字节表示实际长度(长度超过255时需要2个字节),因此最大长度不能超过65535。

b) 编码长度限制

     UTF-8对中文采用3个字节,对英文采用1个字节;GBK对中文采用2个字节,对英文采用1个字节;utf8: 1character=3bytes, 1汉字=1character 也就是说一个字段定义成 varchar(200),则它可以存储200个汉字或者200个字母。gbk: 1character=2bytes,1汉字=1character 也就是说一个字段定义成 varchar(200),则它可以存储200个汉字或者200个字母。

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的原因是实际行存储从第二个字节开始;

       减2的原因是varchar头部的2个字节表示长度;

       除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个字节;

       减30*3的原因是char(30)占用90个字节,编码是utf8。

如果被varchar超过上述的b规则,被强转成text类型,则每个字段占用定义长度为11字节,当然这已经不是“varchar”了。

        

 

 

 

 

--------------------- 作者:wang1046811344 来源:CSDN 原文:https://blog.csdn.net/wang1046811344/article/details/94404172 版权声明:本文为作者原创文章,转载请附上博文链接! 内容解析By:CSDN,CNBLOG博客文章一键转载插件



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有