使用navicat导入数据库时出现Invalid default value for ‘comment_date’错误

在将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 (在Linux中是my.cnf,在Windows中是my.ini)在[mysqld]下面添加如下列:

sql_mode=ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION

重启数据库

[root@VM_01_18_centos ~]# service mysqld restart

数据传输成功了!!!

 

附:[mysql]my.cnf在哪里?

[root@iZj6cfvyf8qms24yyZ ~]# whereis my.cnf
my: /etc/my.cnf

 

————————————————
版权声明:本文为CSDN博主「hughkon」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_40599594/article/details/78216605

Posted in mysql