ERROR 1067 (42000): Invalid default value for ‘lasteventtime‘ (数据库 默认值不能为 “0000-00-00 00:00:00”)

1. ERROR 1067 (42000): Invalid default value for 'lasteventtime'  (对lasteventtime  类型的子段如果不设置缺省值或没有标志not null时候在创建表时会报这个错误)
这是因为sql_mode中的NO_ZEROR_DATE导制的,在strict mode中不允许'0000-00-00 00:00:00'作为合法日期

使用下面的命令查看sql_mode

mysql>show variables like 'sql_mode';

ERROR 1067 (42000): Invalid default value for ‘lasteventtime‘ (数据库 默认值不能为 “0000-00-00 00:00:00”)_第1张图片

将上面的NO_ZERO_DATE改为下面的 ALLOW_INVALID_DATES

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

上面的设置是临时设置,在重新登陆后,该设置又恢复为NO_ZERO_DATE

若报错的话,你再查一下该字段改正过来没有,只要改正了即可

 

这样的话,数据库中的某些表的字段 默认值为“0000-00-00 00:00:00”,也可以创建数据表和添加数据了。

个人而言,需要执行的两步操作:

(1)set sql_mode='ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,ALLOW_INVALID_DATES,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';

(2)set global sql_mode = 'ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';

 

 

++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

若还不行,需要再进行第二步(个人判断是因为 只改了sql_mode,而global.sql_mode也需要改)

  步骤二:先执行select @@global.sql_mode,复制查询出来的值并将其中的NO_ZERO_DATE删除,然后执行set global sql_mode = '修改后的值'。 此方法在当前服务中生效,重新MySQL服务后失效

修改之后若报错,你就执行查询,看看字段改了没有,改了应该就可以了

 

亲测有效!!!

  

另外:在mysql的安装目录下,打开my.ini或my.cnf文件,新增 sql_mode = ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION,然后重启mysql。 此方法永久生效

你可能感兴趣的:(数据库)