mysql中int(m),varchar(m),char(m)的区别

mysql中int(m),varchar(m),char(m)的区别

一、int(m)
当输入值大于m时,m值无效,字段展示长度等于字符长度;
当输入值小于等于m时,如果没有搭配zerofill函数,则m值无效,字段展示长度等于字符长度;
当输入值小于等于m且搭配了zerofill函数时,展示长度为m,有缺失的位置会用0从左进行补充;
m默认为11,无论m为多少,存储空间都为4个字节。

二、char(m)和varchar(m)的区别
1、存储空间上

char为固定长度字符串,存储空间为m个字节,其中1<=m<=255
varchar为可变长度字符串,存储空间L+1个字节,其中L<=m,1<=m<=255

2、展示上

char会将保存值后的空格全部截取掉,varchar则会保留。

3、效率上

char类型每次修改数据类型的长度相同,效率更高
varchar类型每次修改数据类型的长度不同,效率更低

4、使用场景
当字段长度固定时,可以使用char类型以提高效率,如身份证号码(固定18号)等字段。
当字段长度不固定时,可以使用varchar类型,兼容性更强。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值