各位用户为了找寻关于MySQL中CURRENT_TIMESTAMP的使用方式的资料费劲了很多周折。这里教程网为您整理了关于MySQL中CURRENT_TIMESTAMP的使用方式的相关资料,仅供查阅,以下为您介绍关于MySQL中CURRENT_TIMESTAMP的使用方式的详细内容
目录
CURRENT_TIMESTAMP的使用 timestamp使用CURRENT_TIMESTAMP报错
CURRENT_TIMESTAMP的使用
众所周知,MySQL的日期类型可以使用CURRENT_TIMESTAMP来指定默认值,但是这个跟MySQL的版本及日期的具体类型有关,只有5.6之后的版本才能使用CURRENT_TIMESTAMP作为DATETIME的默认值。
例如:
? 1ALTER
TABLE
t_user
ADD
update_time DATETIME
DEFAULT
CURRENT_TIMESTAMP
在5.6之前的版本,使用CURRENT_TIMESTAMP作为默认值时,就会出现下面的错误
[Err] 1067 - Invalid default value for 'update_time'
在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报错
项目出现如下错误:
Error updating database.
Cause:com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException: Column 'createTime' cannot be null
数据模型如下:
? 1 2 3 4/* 创建时间不可为空*/
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”的问题。
? 1 2 3 4 5-- 查看explicit_defaults_for_timestamp默认值
SHOW
GLOBAL
VARIABLES
LIKE
"explicit_defaults_for_timestamp"
;
-- 修改explicit_defaults_for_timestamp默认值
SET
@@
global
.explicit_defaults_for_timestamp=
OFF
;
参数值为"ON"的情况:
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
原文链接:https://blog.csdn.net/u011983531/article/details/71305212