文章目录

问题

用navicat导入数据时,报错:``` [Err] 1292 - Incorrect datetime value: '0000-00-00 00:00:00' for column 'CREATE_TIME' at row 1


![在这里插入图片描述](https://img-hello-world.oss-cn-beijing.aliyuncs.com/ed6c6174f1775f65a3fbe98488391419.png)  



[](https://blog.csdn.net/sinat_40770656/article/details/101198274)原因
====================================================================

这是因为当前的MySQL不支持datetime为0的情况。  



[](https://blog.csdn.net/sinat_40770656/article/details/101198274)解决
====================================================================

修改sql\_mode:  

> sql\_mode:SQL Mode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。



[](https://blog.csdn.net/sinat_40770656/article/details/101198274)全局sql\_mode
-----------------------------------------------------------------------------

查看全局sql\_mode:

select @@global.sql_mode;


可以看到,_O\_ZERO\_DATE、NO\_ZERO\_IN\_DATE_,把这两个设置去掉。

![在这里插入图片描述](https://img-hello-world.oss-cn-beijing.aliyuncs.com/5a6de9bec45cede19ea5576659a3c40d.png)  

修改全局sql\_mode:

set @@global.sql_mode = 'STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';


![在这里插入图片描述](https://img-hello-world.oss-cn-beijing.aliyuncs.com/7d64202358acfde64440e9a8442a6467.png)  


[](https://blog.csdn.net/sinat_40770656/article/details/101198274)当前sql\_mode
-----------------------------------------------------------------------------

查看当前sql\_mode:

select @@sql_mode;


![在这里插入图片描述](https://img-hello-world.oss-cn-beijing.aliyuncs.com/b752a93369460b5146baf7053e177cb4.png)修改当前sql\_mode:

set @@sql_mode = 'STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';


![在这里插入图片描述](https://img-hello-world.oss-cn-beijing.aliyuncs.com/1ad75264b6439abf5132248453d5c660.png)  


OK,问题解决。  

![在这里插入图片描述](https://img-hello-world.oss-cn-beijing.aliyuncs.com/c8192d452bbbe58cc8625312094252b0.png)



上面虽然也可以解决我们的问题,但是一旦MySQL重启,就必须重新设置一次全局和当前的sql\_mode。  


[](https://blog.csdn.net/sinat_40770656/article/details/101198274)修改sql\_mode配置
===============================================================================

在MySQL配置文件mysql.ini中修改sql\_mode配置,就不需要每次重启MySQL就得重新设置sql\_mode了。

*   关闭MySQL

net stop MySQL57


*   修改MySQL配置  
    在my.ini的\[mysqld\]下添加:

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES


*   启动MySQL

net start MySQL57

```


END!

参考:

【1】:https://my.oschina.net/shadowolf/blog/3005188
【2】:https://www.cnblogs.com/mmyy-blog/p/9626326.html
【3】:MySQL事务、锁、SQLMode、分区

转载请注明原文地址:https://www.nomar.cn/?read-517.html
00
New Post(0)