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