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

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

Patricia Arquette
发布: 2024-12-02 08:02:13
原创
230 人浏览过

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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板