MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1

blmius
• 阅读 3340

文章目录

问题

用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、分区

点赞
收藏
评论区
推荐文章
Wesley13 Wesley13
2年前
MySQL binlog2sql实现MySQL误操作的恢复
对于MySQL数据库中的误操作删除数据的恢复问题,可以使用基于MySQL中binlog做到类似于闪回或者生成反向操作的SQL语句来实现,是MySQL中一个非常实用的功能。原理不难理解,基于MySQL的row格式的binlog中,记录历史的增删改SQL信息,基于此解析出来对应的SQL语句(回滚的话就是反向的SQL语句)。在格式为binlog格式为r
Wesley13 Wesley13
2年前
mysql 导入SQL文件报错, Specified key was too long; max key length is 767 bytes
\MySQL导入数据的时候,总是报错,本地测试都没办法测试导出SQL文件正常,在导入SQL文件的时候,报错大部分数据表导入成功,个别的失败     在网上看到很多建议: 1.建议别直接运行sql文件,你可以尝试打开sql文件自己选取sql执行2.Navicat运行SQL文件时,去掉第二个√(每个运
Stella981 Stella981
2年前
Python3:sqlalchemy对mysql数据库操作,非sql语句
Python3:sqlalchemy对mysql数据库操作,非sql语句python3authorlizmdatetime2018020110:00:00coding:utf8'''
Wesley13 Wesley13
2年前
MySQL UPDATE 查询
MySQLUPDATE查询如果我们需要修改或更新MySQL中的数据,我们可以使用SQLUPDATE命令来操作。.语法以下是UPDATE命令修改MySQL数据表数据的通用SQL语法:UPDATEtable_nameSETfield1newvalue1,field2n
Wesley13 Wesley13
2年前
mysql 命令集
sql\_mode定义了mysql应该支持的sql语法,数据校验等select@@sql_mode;属性说明ONLY\_FULL\_GROUP\_BY对于GROUPBY聚合操作,如果在SELECT中的列,没有在GROUPBY中出现,那么将认为这个SQL是不合法的,因为列不在GROUPBY从句中STRICT\_
Stella981 Stella981
2年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Wesley13 Wesley13
2年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
2年前
mysql数据库批量执行sql文件对数据库进行操作【windows版本】
起因:因工作需要,在本机测试环境升级mysql数据库,需逐条执行mysql数据库的sql文件对数据库进行升级,因此找了些关于mysql的文章,对批量升级数据库所需的sql文件进行升级。整理思路:1.首先,需要对所需升级的sql所在目录的sql文件进行遍历。生成新的批量执行sql文件。想到是windows系统安装的mysql,首先
Wesley13 Wesley13
2年前
mysql查询分析以及杂项
MySQL的sql\_mode合理设置sql\_mode是个很容易被忽视的变量,默认值是空值,在这种设置下是可以允许一些非法操作的,比如允许一些非法数据的插入。在生产环境必须将这个值设置为严格模式,所以开发、测试环境的数据库也必须要设置,这样在开发测试阶段就可以发现问题。!(https://oscimg.oschina.net/oscnet/
Python进阶者 Python进阶者
1个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这