情景描述
- 完成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值的。
- mysql自动为他生成一个
- 针对mysql中的第一个TIMESTAMP字段:
-
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设置默认值也可以成功。
- 5.7版本:
- 这取决于你使用的mysql版本了(经过我的测试):
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
。
- TIMESTAMP和DATE设置了默认的限制NOT_NULL,因此不论你写不写NOT—NULL这个限制都存在。并且都会赋予默认值
- mysql:5.7.8
- TIMESTAMP和DATE可以为NULL,并且mysql也不会自动设置默认值给这些字段。
------> 对于5.7版本,你根本不需要为TIMESTAMP和DATE字段设置NOT—NULL字段,人家自带
- mysql:5.7
Q4:那么如何解决这个问题呢?
-
A4:针对mysql:5.7
- 设置:DEFAULT "2017-9-10"
针对mysql:5.7.8
- 如果不要求NOT_NULL,那么不需要设置