美文网首页
mysql数据类型:timestamp

mysql数据类型:timestamp

作者: 张培_ | 来源:发表于2017-09-10 17:40 被阅读21次

    情景描述

    • 完成sql文件,创建mysql table
      CREATE TABLE IF NOT EXISTS growthNote (
      id            INT(11) PRIMARY KEY AUTO_INCREMENT,
      createTime    TIMESTAMP,
      date          TIMESTAMP,
      title         VARCHAR(225)
                    CHARACTER SET utf8
                    COLLATE utf8_bin                    NOT NULL,
      content       VARCHAR(225)
                    CHARACTER SET utf8
                    COLLATE utf8_bin                    NOT NULL,
      author        INT(11)                             NOT NULL,
      rawId         INT(11)                             NOT NULL,
      operationType ENUM ('CREATE', 'UPDATE', 'DELETE') NOT NULL
      )
      ENGINE = InnoDB
      CHARACTER SET utf8
      COLLATE utf8_bin;
      
    • 然后执行./gradlew flywayMigrate
    • 报错:Invalid default value for 'date'

    矛盾点

    • why:没有给date设置过default value ,为什么会爆错说Invalid default value
    • why: 如果说默认值无效,那么是否是mysql给了他默认值,然后给的值无效?
      • 为什么mysql要给他默认值?
      • 为什么是在创建table的时候就给了?
      • 那么mysql会给别的字段默认值吗?
    • why:为什么跟他同一个类型的timestamp类型没有爆出同样的问题?

    问题解决

    • Q1:TIMESTAMP类型是否数据库会给他设置一个default value(当没有显示设置的时候)?如果是,值是什么?

    • A1:默认值一定会设置,并且mysql还会给TIMESTAMP类型设置不同的默认值。(以下前提:针对你没有给该字段设置过任何默认值,并且仅仅针对5.7版本mysql

      • 针对mysql中的第一个TIMESTAMP字段:
        • mysql会自动根据当前时间产生一个VARCHAR(14)的值放入该字段作为数值。
        • 并且会设置on update current_timestamp:意思是当某条记录update的时候,这个字段的值会根据当前的时间产生时间戳更新这个字段的值。
      • 针对mysql中的非第一个TIMESTAMP字段,并且没有设置default和其他任何限制的时候:
        • mysql自动为他生成一个0000-00-00 00:00:00作为值。
        • 因此mysql会自动为timeStamp字段设置default值的。
    • Q2:那么createTime被设置current-time当默认值,date被设置了0000-00-00 00:00:00当默认值,那么为什么第二个默认值会报错呢?

      • 这取决于你使用的mysql版本了(经过我的测试):
        • 5.7版本:
          • 数据库使用严格模式
          • 会依照question1的方式给TIMESTAMP和DATE类型设置默认值
          • 但是sql_mode要求TABEL NO_ZERO_DATE因此,默认设置的0000-00-00 00:00:00会被认为是ZERO_DATE。所以数据库创建失败。
        • 5.7.8版本:
          • 数据库不会自动给TIMESTAMP字段设置默认值。
          • 如果INSERT没有添加数值,就会在字段中插入NULL
          • 并且create table的时候没有给TIMESTAMP设置默认值也可以成功。
    • Q3:那么针对5.7版本数据库,如果我不设置TimeStamp字段是NOT_NULL是不是说数据库就不会给字段设置0000-00-00 00:00:00而是当没有值的时候设置为null?

    • A3:

      • mysql:5.7
        • TIMESTAMP和DATE设置了默认的限制NOT_NULL,因此不论你写不写NOT—NULL这个限制都存在。并且都会赋予默认值0000-00-00 00:00:00
      • mysql:5.7.8
        • TIMESTAMP和DATE可以为NULL,并且mysql也不会自动设置默认值给这些字段。

      ------> 对于5.7版本,你根本不需要为TIMESTAMP和DATE字段设置NOT—NULL字段,人家自带

    • Q4:那么如何解决这个问题呢?

    • A4:针对mysql:5.7

      • 设置:DEFAULT "2017-9-10"

      针对mysql:5.7.8

      • 如果不要求NOT_NULL,那么不需要设置

    相关文章

      网友评论

          本文标题:mysql数据类型:timestamp

          本文链接:https://www.haomeiwen.com/subject/ziltsxtx.html