MySQL中CURRENT_TIMESТAMP的使用方式
目录
-
CURRENT_TIMESТAMP的使用timestamp使用CURRENT_TIMESТAMP报错
CURRENT_TIMESТAMP的使用
众所周知,MySQL的日期类型可以使用CURRENT_TIMESТAMP来指定默认值,但是这个跟MySQL的版本及日期的具体类型有关,只有5.6之后的版本才能使用CURRENT_TIMESТAMP作为DATETIME的默认值。
例如:
ALTER TABLE t_user ADD update_time DATETIME DEFAULT CURRENT_TIMESТAMP在5.6之前的版本,使用CURRENT_TIMESТAMP作为默认值时,就会出现下面的错误
[Err] 1067 – Invalid default value for ‘update_time’
在MySQL 5.6.5版本之前,DEFAULT CURRENT_TIMESТAMP ON UPDATE CURRENT_TIMESТAMP只适用于TIMESТAMP,而且一张表中,最多允许一个TIMESТAMP字段采用该特性。 从MySQL 5.6.5开始, DEFAULT CURRENT_TIMESТAMP ON UPDATE CURRENT_TIMESТAMP同时适用于TIMESТAMP和DATETIME,且不限制数量。
timestamp使用CURRENT_TIMESТAMP报错
项目出现如下错误:
Error updating database.
Cause:com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException: Column ‘createTime’ cannot be null
数据模型如下:
/* 创建时间不可为空*/
createTime timestamp NOT NULL DEFAULT CURRENT_TIMESТAMP COMMENT ‘创建时间’ ,
/* 更新时间不可为空*/
updateTime timestamp NOT NULL DEFAULT CURRENT_TIMESТAMP ON UPDATE CURRENT_TIMESТAMP COMMENT ‘更新时间’ ,经过一系列的问题排查,定位到是因为不同版本的MySQL数据库全局变量“explicit_defaults_for_timestamp”的问题。
— 查看explicit_defaults_for_timestamp默认值
SHOW GLOBAL VARIABLЕS LIKE “explicit_defaults_for_timestamp”;
— 修改explicit_defaults_for_timestamp默认值
SET @@global.explicit_defaults_for_timestamp=OFF;
参数值为”ON”的情况:
以上为个人经验,希望能给大家一个参考,也希望大家多多支持共生网络。
原创文章,作者:starterknow,如若转载,请注明出处:https://www.starterknow.com/117841.html