mysql5.7 创建多个timestamp字段引发的sql异常invalid default value for xxx

数据库建表脚本,如果字段不显示申明不为空,则默认为null,例如

create table user
(
	user_id varchar(255) not null,
	name varchar(255),
	age int
)

但是遇到timestamp类型的字段时,如果只有一个timestamp类型的字段,这样写是没有什么问题的

create table user
(
	create_time timestamp
)

但是如果出现两个这样的字段,sql就会报错,会出现invalid default value for update_time 

create table user
(
	create_time timestamp,
	update_time timestamp
)

如何解决?

1.显式声明null 或者 not null

2.在mysql的my.cnf文件中增加explicit_defaults_for_timestamp=1 

这种错误我是在5.7.18中遇到的,但是拿到5.7.28去测试又没有问题了

#正确写法
create table user
(
	create_time timestamp not null default current_timestamp,                                   # insert默认插入
	update_time timestamp not null default current_timestamp on update current_timestamp        # insert默认插入,update默认更新
)

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值