在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
CURRENT_TIMESTAMP的使用众所周知,MySQL的日期类型可以使用CURRENT_TIMESTAMP来指定默认值,但是这个跟MySQL的版本及日期的具体类型有关,只有5.6之后的版本才能使用CURRENT_TIMESTAMP作为DATETIME的默认值。 例如: ALTER TABLE t_user ADD update_time DATETIME DEFAULT CURRENT_TIMESTAMP 在5.6之前的版本,使用CURRENT_TIMESTAMP作为默认值时,就会出现下面的错误
在MySQL 5.6.5版本之前,DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP只适用于TIMESTAMP,而且一张表中,最多允许一个TIMESTAMP字段采用该特性。 从MySQL 5.6.5开始, DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP同时适用于TIMESTAMP和DATETIME,且不限制数量。 timestamp使用CURRENT_TIMESTAMP报错项目出现如下错误:
数据模型如下: /* 创建时间不可为空*/ createTime timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间' , /* 更新时间不可为空*/ updateTime timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间' , 经过一系列的问题排查,定位到是因为不同版本的MySQL数据库全局变量“explicit_defaults_for_timestamp”的问题。 -- 查看explicit_defaults_for_timestamp默认值 SHOW GLOBAL VARIABLES LIKE "explicit_defaults_for_timestamp"; -- 修改explicit_defaults_for_timestamp默认值 SET @@global.explicit_defaults_for_timestamp=OFF; 参数值为"ON"的情况: 以上为个人经验,希望能给大家一个参考,也希望大家多多支持极客世界。 |
请发表评论