赞
踩
Incorrect datetime value: '0000-00-00 00:00:00'
,报错详情如下所示。xxx
VALUES (xxxx0000-00-00 00:00:00
呢?官方文档上说明MySQL允许将’0000-00-00’保存为“伪日期”(如果不使用NO_ZERO_DATE SQL模式)。这在某些情况下比使用NULL值更方便(并且数据和索引占用的空间更小)。
sql_mode
,取消NO_ZERO_DATE
。show variables like '%sql_mode%';
,结果如下。Value: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
然后再看测试环境的。
对比下很容易发现,的确是没有NO_ZERO_DATE
的。
现在我们修改mysql的my.cnf
文件,修改sql_mode
(如果没有就新增,放在[mysqld]下面),去掉NO_ZERO_DATE
。代码如下所示。
sql_mode=ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。