int(11)到底占几个字节,亲测保证可靠

前言

你是不是一直以为Int(11)就是占11个字节,int(3)就是占3个字节,如果你是这样想的那就大错特错了,这里小编就带着大家一起重新巩固学习吧,打破之前的错误“认为”。

开始测试

第一步:我将c字段的数据类型设置成了int(11)
在这里插入图片描述

接下来我进行插入数据,报出了如下信息:
在这里插入图片描述
怎么回事?不应该是成功返回信息嘛。但我插入9条数据的时候,成功了
在这里插入图片描述

这里我插入10也没成功,这里就不再展示了。正想为什么的时候,我进行了第二步测试。

第二步测试:

我将int(11)改成了int(15),但最后发现插入的还是9个数字,字节还是9个字节。

第三步测试:

我又改成了int(4)与及小于11的数字,发现都是1个字节。
在这里插入图片描述
这是怎么回事呢?但如果是varchar不是这样,varchar(11)就存11个字符,varchar是变长的,varchar(m)只是它的长度范围,但根据他的范围对于长度也是有限制的

第四步测试:颠覆上面步骤的认知

上面我用repeat测的时候发现只能插入9个数字,所以我误认为Int(11)是只能插入9个字节,但最后发现是能插入10个长度,但不管插入多少长度,int是固定的就是占四个字节。int(3)和Int(11)只是他们占的长度不一样而已,在使用上并没有什么区别,其Int(M)这个M就是长度,这个长度如果超出了则没有影响,没有超出会在数的前面用0补齐。

为什么能插入10个长度呢?
因为一个字节占8位,int四个字节就是32位,所以范围大小就是正负2的31次方

总结

在做测试验证的时候不要仅限于一种方式,有时自己做的操作也许因为某一个函数或者书籍问题,将会导致测试数据出错。所以需要全面了解。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值