Mysql8 中 时间类型字段-timestamp时间戳,设置了不为空 并默认值为 CURRENT_TIMESTAMP,但插入空的时间报错问题


Mysql8中时间字段-timestamp时间戳,设置了不为空 并默认值为 CURRENT_TIMESTAMP,但插入空的时间报错问题

Error:1048 - Column ‘createTime‘ cannot be null

原因:

mysql8.0 新增了持久化修改全局变量

explicit_defaults_for_timestamp 系统变量决定MySQL服务端对timestamp列中的默认值和NULL值的不同处理方法。 此变量自MySQL 5.6.6 版本引入,分为全局级别和会话级别,可动态更新,默认值为OFF。 在8.0之中默认值改为了on


解决: 方法1:换用datetime属性

方法2:执行以下sql语句,重启mysql服务

-- 可查看`explicit_defaults_for_timestamp`的值
SHOW GLOBAL VARIABLES LIKE "explicit_defaults_for_timestamp";

-- 使用 set persist 和修改配置文件的效果一致,重启之后无需再改一遍了
SET persist explicit_defaults_for_timestamp=OFF;

mysql8.0 新增了持久化修改全局变量, 使用 set persist 和修改配置文件的效果一致,重启之后无需再改一遍了.

报错场景:
-- 1.用户表t_user
CREATE TABLE `t_user` (
  `id` int(11) NOT NULL AUTO_INCREMENT, -- 用户编号
  `username` varchar(32) DEFAULT NULL,	-- 用户名字
  `password` varchar(32) DEFAULT NULL,	-- 用户密码
  `email` varchar(32) DEFAULT NULL,		-- 用户邮箱
  `createTime` timestamp not NULL DEFAULT CURRENT_TIMESTAMP, -- 该用户创建时间
  `updateTime` timestamp not NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, -- 该用户修改时间
  PRIMARY KEY (`id`) -- 设置主键
) ENGINE=InnoDB DEFAULT CHARSET=utf8

insert into t_user values (null,'admin','1234','admin@163.com',null,null);

执行插入语句时报错:
1048 - Column ‘createTime’ cannot be null

原因:

explicit_defaults_for_timestamp 系统变量决定MySQL服务端对timestamp列中的默认值和NULL值的不同处理方法。 此变量自MySQL 5.6.6 版本引入,分为全局级别和会话级别,可动态更新,默认值为OFF。 在8.0之中默认值改为了on**

  • explicit_defaults_for_timestamp=OFF,表示使用默认的timestamp默认格式;timestamp类型的默认格式是什么样的呢?

1.和其它字段类型不一样,这个字段默认为not null.而且不允许设置default null. 2.第一列timestamp字段,如果不强制指定默认值或on update属性的话,就会默认设为DEFAULT CURRENT_TIMESTAMP和ON UPDATE CURRENT_TIMESTAMP。 3.非第一列timestamp字段,如果不强制指定默认值,DEFAULT ‘0000-00-00 00:00:00’ 4.往该列中插入null值,会自动转化为默认值;

  • explicit_defaults_for_timestamp=ON,则关闭timestamp default的特性:

1.如果没有被显示指定not null,则默认为null; 2.默认值也会是null而非CURRENT_TIMESTAMP; 3.如果指定了not null属性,inset式不指定该字段的值,strict sql_mode下,会报错。非strict sql_mode下插入’0000-00-00 00:00:00’;

需要仔细考虑下面的场景:

1、timestamp not null default CURRENT_TIMESTAMP,当explicit_defaults_for_timestamp由0转为1时会带来什么业务影响? 这样的转化,如果该timestamp字段有默认值,会造成原本insert 该timestamp字段value为null的语句会插入失败,影响业务; 2、datetime default null 转成 timestamp default CURRENT_TIMESTAMP,又会带来什么业务影响呢? 做这样的字段转化,会把原本该字段为null的值都转化为CURRENT_TIMESTAMP,如果历史数据多的化,这样的转化是非常耗资源的。同时还需考虑值的转变对业务带来的影响。

原文链接:https://blog.csdn.net/mmmmmCJP/article/details/116755901

常见错误
JAVA-技能点