zoukankan      html  css  js  c++  java
  • mysql创建表

    CREATE TABLE table_name (column_name column_type);
    可以追加字段属性:
      

    MySQL字段属性  https://www.cnblogs.com/geaozhang/p/6786105.html

    MySQL有如下字段属性:

    MySQL关键字含义
    NULL 数据列可包含NULL值
    NOT NULL 数据列不允许包含NULL值
    DEFAULT 默认值
    PRIMARY KEY 主键
    AUTO_INCREMENT 自动递增,适用于整数类型
    UNSIGNED 无符号
    CHARACTER SET name 指定一个字符集

    关于length属性

    MySQL支持给一个数值类型添加一个length属性,它代表这个字段值的展示宽度。比如INT(4)定义了这个字段会按四个字符的宽度进行展示。这个功能有什么用呢?当我们在查询这个字段时,如果字段值小于定义的展示宽度,那么在展示时系统会自动在这个数值的左侧通过空格进行补齐。

    这个length属性只是定义了展示数值的宽度,绝对不会影响数值实际存储的大小。不管我们定义的是INT(4)、INT(11)还是INT(20),我们最终存储的数值大小都占4个字节, 范围都是 (-2 147 483 648,2 147 483 647)。当实际存储的数值宽度大于我们定义的宽度时,会按实际宽度进行展示。比如我们定义的宽度时INT(5),而实际数值是123456共6位,那么查询时显示的还是123456。

    总之一句话,length属性只会在实际数值宽度小于我们定义的宽度时才用空格进行补齐,任何情况下都不会影响实际数值的存储和展示。

    关于zerofill属性

    当length属性结合zerofill属性一起使用时,补齐的就不是空格了,而是0。比如我们定义的列属性为INT(4) ZEROFILL,如果数据库中存储的值是5的话,查询出来便会是0005。注意,此时数据库中的值依然是5,只是查询出来是0005。

    关于unsigned属性

    如果我们使用了unsigned,则存储的最大值翻倍,如tinyint unsigned的取值范围就由(-128~127)变成了(0~256)。 
    如果我们定义的列是zerofill的,那么MySQL会自动给这个列加上unsigned属性。

    关于autoincrement属性

    如果我们给一个列添加了autoincrement属性,那么当我们插入null或0值时,列值便会自动设置成下一个序列号,一般是当前value+1。注意,只有当列值属性设置为NOT NULL时,插入null值才会autoincrement,否则便会直接插入null值

     
  • 相关阅读:
    懒人的gitlab安装
    SuperFish插件实现鼠标停留浮动的菜单栏.
    Bootstrap I
    京东首页样式分析.
    CentOs装VLC
    TI CC2541的通讯抓包.
    ffmpeg+ffserver实现摄像头直播
    arm linux上的第一个应用程序 BOA移植
    linux内核移植 I
    uboot启动参数
  • 原文地址:https://www.cnblogs.com/zzqc/p/9198678.html
Copyright © 2011-2022 走看看