ERROR 1067 (42000): Invalid default value for 'end_time'
admin
2023-05-16 04:41:56
0

版本:mysql5.7

执行sql:

CREATE TABLE seckill(
  `seckill_id` BIGINT NOT NUll AUTO_INCREMENT COMMENT '商品库存ID',
  `name` VARCHAR(120) NOT NULL COMMENT '商品名称',
  `number` int NOT NULL COMMENT '库存数量',
  `start_time` TIMESTAMP  NOT NULL  COMMENT '秒杀开始时间',
  `end_time` TIMESTAMP  NOT NULL  COMMENT '秒杀结束时间',
  `create_time` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  PRIMARY KEY (seckill_id),
  key idx_start_time(start_time),
  key idx_end_time(end_time),
  key idx_create_time(create_time)
)ENGINE=INNODB AUTO_INCREMENT=1000 DEFAULT CHARSET=utf8 COMMENT='秒杀库存表';

执行结果:ERROR 1067 (42000): Invalid default value for 'end_time'

原因是:mysql5.7的explicit_defaults_for_timestamp参数默认是OFF与sql_mode的NO_ZERO_DATE冲突

通过执行mysql>show variables;查看explicit_defaults_for_timestamp和sql_mode变量的值

explicit_defaults_for_timestamp    =    OFF

sql_mode = ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

分析过程:

1)在默认情况下,如果TIMESTAMP列没有显示的指明null属性,那么该列会被自动加上not null属性(而其他类型的列如果没有被显示的指定not null,那么是允许null值的),如果往这个列中插入null值,会自动的设置该列的值为current timestamp值。

2)表中的第一个TIMESTAMP列,如果没有指定null属性或者没有指定默认值,也没有指定ON UPDATE语句。那么该列会自动被加上DEFAULT CURRENT_TIMESTAMP和ON UPDATE CURRENT_TIMESTAMP属性。

3)第一个TIMESTAMP列之后的其他的TIMESTAMP类型的列,如果没有指定null属性,也没有指定默认值,那么该列会被自动加上DEFAULT ‘0000-00-00 00:00:00’属性。如果insert语句中没有为该列指定值,那么该列中插入’0000-00-00 00:00:00’,并且没有warning。

解决办法:

mysql>set @@explicit_defaults_for_timestamp = 1;

1)此时如果TIMESTAMP列没有显示的指定not null属性,那么默认的该列可以为null,此时向该列中插入null值时,会直接记录null,而不是current timestamp。

2)不会自动的为表中的第一个TIMESTAMP列加上DEFAULT CURRENT_TIMESTAMP和ON UPDATE CURRENT_TIMESTAMP属性,除非你在建表的时候显示的指明。

3)如果TIMESTAMP列被加上了not null属性,并且没有指定默认值。这时如果向表中插入记录,但是没有给该TIMESTAMP列指定值的时候,如果strict  sql_mode被指定了,那么会直接报错。如果strict sql_mode没有被指定,那么会向该列中插入’0000-00-00 00:00:00’并且产生一个warning。


NO_ZERO_DATE:

在这个模式下,不允许时间值为'0000-00-00 00:00:00'格式;

解决办法:

mysql>set @@sql_mode='ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';

去掉NO_ZERO_IN_DATE,NO_ZERO_DATE

重启服务器,正常执行创建语句.

相关内容

热门资讯

燃气热水器通电显示屏不亮 1、可能是燃气热水器的显示屏连接线发生断路的情况。2、可能是家庭内的电压出现大幅度波动,或者电压过低...
长虹电视机开机后显示屏不亮是什... 果液晶电视出现这种情况的话,很有可能是由于电视内部排线接触不好造成的。因为在液晶电视内部,各个援建在...
墙面扣板材料有哪几种类型 现代墙面装饰材料种类众多,不局限油漆涂料,市面上还有各种扣板材料。那么墙面扣板材料有哪几种呢??马上...
白墙有个坑怎么补好 1、首先需要准备腻子粉和刮刀。2、对白墙磕碰的小坑处进行打磨,先使用磨砂纸把小坑磨平以后,再把表面的...
马桶坑距一般多少 马桶的坑距一般都是在300mm、350mm、400mm、450mm的范围,坑距指的是马桶排污口与墙面...
全国智能化医学装备医疗器械来津... 昨天,2026医学装备创新大赛暨“医心杯”医疗器械创新创业大赛天津城市赛举行,来自全国的130余支参...
多功能搅拌釜:工业生产中的通用... 在各类工业生产领域中,多功能搅拌釜是物料加工的核心设备,集成搅拌、分散、均质等多项功能,广泛应用于化...
江西一地遭遇暴雨,街道上积水最... 极目新闻记者 刘琴5月16日,江西省赣州市上犹县不少居民发布的视频显示,上犹县县城的部分区域经历一晚...
中菲执法部门合作遣返重大跨境赌... 近日,中国和菲律宾两国执法部门合作抓获遣返涉嫌组织跨境赌博犯罪的陈某某。陈伙同他人在境外搭建非法赌博...
网友炸了!花 6000 万美元... 来源:科技狐 聊一下今天全网爆火的 “ 央视 6000 万美元拿下 2026 世界杯转播权 ” 话题...