Mysql - int(1)、int(20) 的区别
在设计数据库表的时候,经常需要设计一个id字段,它的类型一般都是整型int,经常会遇到int(1)、int(20)等。
int的范围:
有符号的整型范围是-2147483648~2147483647
无符号的整型范围是0~4294967295
参看 MySQL 手册,int(M): M indicates the maximum display width for integer types.
int(M)只是用来显示数据的宽度,在 integer 数据类型中,M 表示最大显示宽度,一般int后面的数字M要配合zerofill一起使用才有效。
数据准备
创建测试表 test_table,包含两个测试字段area_1 int(1)、area_2 int(20):
CREATE TABLE `test_table` (
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
`area_1` int(1) unsigned DEFAULT NULL,
`area_2` int(20) unsigned DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
存储大小
在 MySQL 中 int 类型占4个字节,对于无符号整形最大值为:2^32-1 = 4294967295,下面看看int(1)、int(20)分别可以存储 int 类型最大值?
INSERT INTO `test_table` (`area_1`, `area_2`) VALUES (4294967295, 4294967295)
> Affected rows: 1
> 查询时间: 0.002s
插入成功,int(1)、int(20) 都可以存储 int 类型最大值,说明对存储大小无影响。那么1和20用什么作用呢?答案就是对齐填充,当联合零填充(zerofill) 使用时,配置的值才会体现效果。
零填充(zerofill,一般int后面的数字要配合zerofill一起使用才有效)
所谓零填充就是当数字位小于指定位数时,使用0填充补全位数,比如指定位数为4位,数为23,那么实际会被填充为 0023。
将 area_1 和 area_2 字段配置为 zerofill:
CREATE TABLE `test_table` (
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
`area_1` int(1) unsigned zerofill DEFAULT NULL,
`area_2` int(20) unsigned zerofill DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8mb4;
可以看到 area_2 不足20位时使用0补齐到20位,area_1 指定位数为 1 位实际并没有效果,因为数字至少为1位,对 NULL 不生效。
零填充(zerofill)在一些需要数字对齐的场景中可能使用,但实践中并不推荐,对数据库依赖性太强。
总结
int后面的数字不能表示字段的长度,int(num)一般加上zerofill,才有效果。
一般整型而言,对于int(1)、int(20) 中指定的位数并不会影响字段的存储大小,而是和零填充(zerofill)联合使用实现对齐填充,实际使用中没有特殊对齐需求,配置为int(1)即可。
注意:零填充只针对于整型,字符串(char、varchar)的“长度”是会受到真正的限制。Char(n)、Varchar(n),括号里的N表示的是该字段可容纳的最大字符数,简单来说就是能存入多少个字符,n的取值范围为:0-255。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· DeepSeek 开源周回顾「GitHub 热点速览」