MySQL中int(1)与int(8)的区别

本文共 635 字,预计阅读时间 2 分钟

当你看到这个问题时,你会给出什么答案?

先说结论:两者没有区别,它们存储的长度是一样的。

1)先创建一个表:包含两个4个字段用于测试

复制代码
create table user(
    id int(8) not null,
    id2 int(8) zerofill not null  ,
    type int(1) not null,
    type2 int(1) zerofill not null  
);
复制代码

上述4个字段中,第1和2及第3和4分别存储一样的值,只是第2和4设置了zerofill属性,作用是根据设置的长度进行判断,如果值长度不够,在前面补0。

2)插入数据

insert into user values(2001,2001,1,1);
insert into user values(2002,2002,0,0);
insert into user values(2003,2003,0,0);
insert into user values(2004,2004,1,1);

3)使用MySQL控制台查询数据

从图中可以发现,同为int(8)类型的id,显示却不同,实际上是设置zerofill属性后就显示了8位的值。

究其原理,int类型无论设置其长度是多少,都能存储11位数字,但显示的值的长度是设置的长度。因此,int(1)和int(8)没有区别。

posted @   钟小嘿  阅读(853)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
历史上的今天:
2021-04-23 SQL中 left join on 后用 and 还是 where的区别
点击右上角即可分享
微信分享提示