最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
MySQL中CURRENT_TIMESTAMP使用方式代码示例
时间:2022-06-29 08:37:16 编辑:袖梨 来源:一聚教程网
本篇文章小编给大家分享一下MySQL中CURRENT_TIMESTAMP使用方式代码示例,文章代码介绍的很详细,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看。
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作为默认值时,就会出现下面的错误
[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
数据模型如下:
/* 创建时间不可为空*/ 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"的情况:
相关文章
- 铁路12306免费版极速下载-铁路12306官方免费版一键安装 12-27
- 漫蛙漫画官方版最新版本安装包下载-漫蛙漫画网站官方正版免费安装 12-27
- 微博手机网页版入口在哪找-微博网页版最新官方访问地址 12-27
- 游咔下载-游咔app官方正版安卓最新版 12-27
- 长佩文学城官网入口-长佩文学城正版阅读入口 12-27
- 撕掉她的外衣6安卓版游戏安装包下载-撕掉她的衣服简化版最新版本免费下载 12-27
