在一次升级过程中,发现Mysql插入数据报了个错
Column 'create_time' cannot be null.
但是看了下这个字段虽然是非null,但是是有默认值的
`create_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP
报这个错的原因是往这个字段里插入了null,但是没有用默认值代替null
看了下本地和服务器的Mysql版本都是5.7,在本地是没有问题的
最后发现是有一个explicit_defaults_for_timestamp
参数去控制timestamp
的列的默认值还是NULL
show variables like 'explicit_defaults_for_timestamp';
这个参数默认为off
当设置为off
时:
如果往这个列中插入null值,会自动的设置该列的值为current timestamp值
当设置为on
时:
此时向该列中插入null值时,会直接记录null,而不是current timestamp
修改参数可以使用set或者修改my.cnf配置,set重启会失效
//改成off
set GLOBAL explicit_defaults_for_timestamp = 1
参考:https://segmentfault.com/a/1190000018818020
文章评论