mysql数据库中int(4)的意义(原创)

mysql数据库中int(4)的意义

在char和varchar这些类型的字段中,如果设置varchar(4),那么最大只能保存4个字符。因此许多人包括本人也一直以为int类型能存储的整数长度也和int字段的长度有关。

但是今天经过测试,发现int类型似乎并不是通常我们大多数人所认为的那样。

在没有为mysql 字段设置零填充 zerofill属性的时候,int(1)和int(11)没有任何区别。 

测试发现int(1)和int(11),可以存储的最大数值都是 2147483647 。21亿。

但是,有一个奇怪的事情,字段在设置zerofill属性后,可以存储的最大数值居然翻了一倍,变成4294967295。 42亿。

字段在设置zerofill属性后,int(4)显示0003,而int(11)显示00000000003 (int类型最长支持11位)

也就是说,int(4),这个4不是指的int整型的长度,而是指设置zerofill属性后自动在前头填充0的位数。

经过以上测试,也就是说,以后建表的时候,如果不需填充0的话,似乎可以不用再为int字段设置长度了。

本测试基于 mysql 5.6版本。 

 

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值