mysql数据类型:timestamp

情景描述

  • 完成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)