解決:Invalid default value for 某字段


在將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

類似的問題,都可以用這個思路來解決。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM