首页 » 网站建设 »

解决:Invalid default value for 某字段

2019年5月11日 / 1,546次阅读
MySQL

在将WordPress的数据库从MySQL5.6导入MySQL5.7的过程中,出现了Invalid default value for 'comment_date'这个错误。

错误原因是因为MySQL5.7的默认sql_mode配置。

mysql> show variables like 'sql_mode';
+---------------+-------------------------------------------------------------------------------------------------------------------------------------------+
| Variable_name | Value |
+---------------+-------------------------------------------------------------------------------------------------------------------------------------------+
| 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 row in set (0.00 sec)

默认sql_mode里面有NO_ZERO_IN_DATE,NO_ZERO_DATE这两个选项。从名称上看,就是表示Date数据不能为0。

而WordPress的wp_comments表格,在创建的时候,Date就是0:
`comment_date` datetime(0) NOT NULL DEFAULT '0000-00-00 00:00:00',
`comment_date_gmt` datetime(0) NOT NULL DEFAULT '0000-00-00 00:00:00',

所以,解决这个问题的方法,就是修改sql_mode的配置。

在my.cnf文件中,修改sql_mode的配置,将NO_ZERO_IN_DATE,NO_ZERO_DATE这两个选项去掉。

sql_mode=ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

类似的问题,都可以用这个思路来解决。

本文链接:https://www.maixj.net/wz/invalid-default-value-for-21279

相关文章

留言区


前一篇:
后一篇:

栏目精选

云上小悟,麦新杰的独立博客

Ctrl+D 收藏本页

栏目


©Copyright 麦新杰 Since 2014 云上小悟独立博客版权所有 备案号:苏ICP备14045477号-1。云上小悟网站部分内容来源于网络,转载目的是为了整合信息,收藏学习,服务大家,有些转载内容也难以判断是否有侵权问题,如果侵犯了您的权益,请及时联系站长,我会立即删除。

网站二维码
go to top