首页 >数据库 >mysql教程 >为什么我在 MySQL 中收到''created_at' 的默认值无效”错误?

为什么我在 MySQL 中收到''created_at' 的默认值无效”错误?

Patricia Arquette
Patricia Arquette原创
2024-12-02 08:02:13297浏览

Why Am I Getting an

MySQL 中“created_at”错误的默认值无效

尝试修改表时,出现以下错误消息:

ERROR 1067 (42000): Invalid default value for 'created_at'

此错误通常在更改时间戳列时出现,但在本例中,它是在添加新专栏。受影响的表有“created_at”和“updated_at”列作为最后两个条目。

解决方案

此错误的原因在于 SQL 模式设置。要解决此问题,请使用以下命令验证当前的 SQL 模式:

show variables like 'sql_mode' ; 

如果 SQL 模式包括“NO_ZERO_IN_DATE,NO_ZERO_DATE”,请删除这些设置以解决问题。这些设置是较新版本的 MySQL 中的默认设置。

作为 root 用户,您可以使用以下命令全局修改 SQL 模式:

set global sql_mode = 'ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';

以上是为什么我在 MySQL 中收到''created_at' 的默认值无效”错误?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn