程序中的string类型,在mysql数据表中可以有三种对应的类型:char、varchar和text。
char、varchar和text的区别
char:定长字符串,最大长度255字节,不足255字节的部分用空格补齐,数据库检索出char类型的数据表数据时会自动截断后面的空格,也就是说字符串后面自带的空格也会被删掉,使用要小心。定长的好处是存取更高效。
varchar:可变长字符串,最大长度65535字节,例如: 当varchar(10)字段类型中插入"abc"时,实际存储大小也只有3个字节,此外,varchar还需要使用1个额外字节来记录字符串的长度。
text:最大长度是65535,在5.0.3以下的版本中varchar最大长度限制为255,那个时候只能用text类型来存放长字符串,在以后的新版本中其实用varchar就可以满足了。此外,text不可以有默认值。
总结
三种类型的选择原则可以总结为:尽可能用varchar,varchar基本是万金油。
其他情况:
- 长度固定可以用char,存取效率高。
- mysql 5.0.3版本以下,超过255字节的字符串只能用text类型,除此之外都不要用text,能用varchar就尽量用varchar。