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

  • 相关阅读:
    XCode Playground Overview
    Swift开发学习(二):Playground
    swift网址
    swift关于is和as的解释
    Swift之 ? 和 !
    Swift 学习之二十一:?和 !(详解)
    Swift学习三
    Makefile project
    20171110面试笔记 服务器端程序员+C/C++开发
    关键字
  • 原文地址:https://www.cnblogs.com/zys2019/p/16176197.html
Copyright © 2020-2023  润新知