CHAR和VARCHAR类型类似,都用来存储字符串,但它们“保存”和“检索”的方式不同。CHAR属于“固定长度”的字符串,而VARCHAR属于“可变长度”的字符类型。

下表显示了将各种字符串值保存到CHAR(4)和VARCHAR(4)列后的结果,说明了CHAR和VARCHAR之间的差别。

CHAR和VARCHAR的对比

值
CHAR(4)
存储需求
VARCHAR(4)
存储需求
''
'    '
4个字节
''
1个字节
'ab'
'ab  '
4个字节
'ab'
3个字节
'abcd'
'abcd'
4个字节
'abcd'
5个字节
'abcdefgh'
'abcd'
4个字节
'abcd'
5个字节

注意上表中最后一行的值只适用mysql运行在非“严格模式”时,如果mysql运行在严格模式,超过列长度的值将不会保存,并且会出现错误提示。

从CHAR(4)和VARCHAR(4)列检索的值并不总是相同,因为检索时从CHAR列删除了尾部的空格。下面通过一个例子来说明该差别:

mysql数据类型char和varchar mysql中varchar和char_mysql 的 char类型的数据类型

由于CHAR是固定长度的,所以它的处理速度比VARCHAR快得多,但是其缺点是浪费存储空间,程序需要对行尾空格进行处理,所以对于那些长度变化不大并且对查询速度有较高要求的数据可以考虑使用CHAR类型来存储。

另外,随着mysql版本的不断升级,VARCHAR数据类型的性能也在不断改进并提高,所以在许多的应用中,VARCAHR类型被更多地使用。

在mysql中,不同的存储引擎对CHAR和VARCHAR的使用原则有所不同,这里简单概括如下。

MyISAM存储引擎:建议使用固定长度的数据列代替可变长度的数据列。

MEMORY存储引擎:目前都使用固定长度的数据行存储,因此无论使用CHAR或VARCHAR列都没有关系。两者都是作为CHAR类型处理。

InnoDB存储引擎:建议使用VARCHAR类型。对于InnoDB数据表,内部的行存储格式没有区分固定长度和可变长度列(所有数据行都使用指向数据列值的头指针),因此在本质上,使用固定长度的CHAR列不一定比使用可变长度VARCHAR列性能要好。因而,主要的性能因素是数据行使用的存储总量。由于CHAR平均占用的空间多于VARCHAR,因此使用VARCHAR来最小化需要处理的数据行的存储总量和磁盘I/O是比较好的。