mysql类型char, varchar和text的区别

程序中的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。

参考

mysql中char,varchar与text类型的区别和选用

MySQL中char 与 varchar

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值