MySQL 数据库的varchar类型在4.1如下的版本中的最大长度限制为255,其数据范围能够是0~255或1~255(根据不一样版本数据库来定)。在 MySQL5.0以上的版本中,varchar数据类型的长度支持到了65535,也就是说能够存放65532个字节的数据,起始位和结束位占去了3个字 节,也就是说,在4.1或如下版本中须要使用固定的TEXT或BLOB格式存放的数据可使用可变长的varchar来存放,这样就能有效的减小数据库文 件的大小。
MySQL 数据库的varchar类型在4.1如下的版本中,nvarchar(存储的是Unicode数据类型的字符)无论是一个字符仍是一个汉字,都存为2个字节 ,通常用做中文或者其余语言输入,这样不容易乱码 ;varchar: 汉字是2个字节,其余字符存为1个字节 ,varchar适合输入英文和数字。
4.0版本如下,varchar(20),指的是20字节,若是存放UTF8汉字时,只能存6个(每一个汉字3字节) ;
5.0版本以上,varchar(20),指的是20字符,不管存放的是数字、字母仍是UTF8汉字(每一个汉字3字节),均可以存放20个,最大大小是65532字节 ;
varchar(20)在Mysql4中最大也不过是20个字节,可是Mysql5根据编码不一样,存储大小也不一样,具体有如下规则:
a) 存储限制
varchar 字段是将实际内容单独存储在聚簇索引以外,内容开头用1到2个字节表示实际长度(长度超过255时须要2个字节),所以最大长度不能超过65535。
b) 编码长度限制
字符类型若为gbk,每一个字符最多占2个字节,最大长度不能超过32766;
字符类型若为utf8,每一个字符最多占3个字节,最大长度不能超过21845。
若定义的时候超过上述限制,则varchar字段会被强行转为text类型,并产生warning。
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。
---------------------------------------------------------------------
mysql的vachar字段的类型虽然最大长度是65535,可是并非能存这么多数据,最大能够到65533(不容许非空字段的时候),当容许非空字段的时候只能到65532。
总结char,varchar,text区别
长度的区别,char范围是0~255,varchar最长是64k,可是注意这里的64k是整个row的长度,要考虑到其它的column,还有若是存在not null的时候也会占用一位,对不一样的字符集,有效长度还不同,好比utf8的,最多21845,还要除去别的column,可是varchar在通常状况下存储都够用了。若是遇到了大文本,考虑使用text,最大能到4G。mysql
效率来讲基本是char>varchar>text,可是若是使用的是Innodb引擎的话,推荐使用varchar代替charsql
char和varchar能够有默认值,text不能指定默认值数据库