当你看到这个问题时,你会给出什么答案?
先说结论:两者没有区别,它们存储的长度是一样的。
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)没有区别。