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


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

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

    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)没有区别。

  • 相关阅读:
    poj 2362 Square (dfs+剪枝)
    三种素数筛法汇总
    2009’河北省高教网络技能大赛一网站建设部分
    寒假每一天
    寒假每一天
    寒假每一天
    寒假每一天
    统计文本文件
    寒假每一天
    寒假每一天
  • 原文地址:https://www.cnblogs.com/zys2019/p/16176197.html
Copyright © 2020-2023  润新知