前言
你是不是一直以为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次方
总结
在做测试验证的时候不要仅限于一种方式,有时自己做的操作也许因为某一个函数或者书籍问题,将会导致测试数据出错。所以需要全面了解。