char类型与varchar类型的区别

char类型:定长字符串,char(n),n的范围:0-255个字符

char类型之所以叫定长字符串,是因为一旦确定了n的最大字符数,不管存的数据是多少,该数据占用的空间就是n个字符。例如:name char(10),存入“张三丰”,存了3个字符,剩余的空间会用空格补全。因此char类型可能会浪费空间。
但在存储长度固定的数据时,char类型相比varchar类型速度要快一些,因为char类型只需判断一个数据是否能存入该列中,而不需要将剩余的空间留给别的数据使用!

varchar类型:变长字符串,varchar(n),n的范围:0-65535个字符

varchar类型之所以叫变长字符串,是因为n只是限制该列中最多能存的字符数,如果你实际存的数据量小于n,剩余的空间还可以留给别的数据使用。例如:name varchar(10),存入‘张’,存入1个字符,剩余的9个空间会留给别的数据使用!
因此varchar类型不会浪费空间!所有varchar类型适合存储长度不固定的数据

总结

1.char和varchar存的数量是不同的,char类型最多能存255个字符,varchar类型最多能存65535个字符。
2.char类型如果存的数据量小于最大长度,剩余的空间会使用空格填充,因此可能会浪费空间,所以char类型适合存储长度固定的数据,这样既不会浪费空间,效率还比varchar略高。
3.varchar类型如果存到数据量小于最大长度,剩余的空间会留给别的数据使用,所以varchar类型适合存储长度不固定的数据,这样虽然没有char存储效率高,但至少不会浪费空间。
4.这个两个类型的范围设置的适合,也会一种优化数据库的好方法。

  • 1
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值