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。

posted @   李若盛开  阅读(400)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· DeepSeek 开源周回顾「GitHub 热点速览」
点击右上角即可分享
微信分享提示