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

blmius
• 阅读 1786

文章目录

问题

用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
1年前
MySQL binlog2sql实现MySQL误操作的恢复
对于MySQL数据库中的误操作删除数据的恢复问题,可以使用基于MySQL中binlog做到类似于闪回或者生成反向操作的SQL语句来实现,是MySQL中一个非常实用的功能。原理不难理解,基于MySQL的row格式的binlog中,记录历史的增删改SQL信息,基于此解析出来对应的SQL语句(回滚的话就是反向的SQL语句)。在格式为binlog格式为r
Wesley13 Wesley13
1年前
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
1年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Wesley13 Wesley13
1年前
mysql数据库批量执行sql文件对数据库进行操作【windows版本】
起因:因工作需要,在本机测试环境升级mysql数据库,需逐条执行mysql数据库的sql文件对数据库进行升级,因此找了些关于mysql的文章,对批量升级数据库所需的sql文件进行升级。整理思路:1.首先,需要对所需升级的sql所在目录的sql文件进行遍历。生成新的批量执行sql文件。想到是windows系统安装的mysql,首先
Wesley13 Wesley13
1年前
mysql查询分析以及杂项
MySQL的sql\_mode合理设置sql\_mode是个很容易被忽视的变量,默认值是空值,在这种设置下是可以允许一些非法操作的,比如允许一些非法数据的插入。在生产环境必须将这个值设置为严格模式,所以开发、测试环境的数据库也必须要设置,这样在开发测试阶段就可以发现问题。!(https://oscimg.oschina.net/oscnet/
Wesley13 Wesley13
1年前
PHP中的NOW()函数
是否有一个PHP函数以与MySQL函数NOW()相同的格式返回日期和时间?我知道如何使用date()做到这一点,但是我问是否有一个仅用于此的函数。例如,返回:2009120100:00:001楼使用此功能:functiongetDatetimeNow(){
3A网络 3A网络
2个月前
理解 virt、res、shr 之间的关系(linux 系统篇)
理解virt、res、shr之间的关系(linux系统篇)前言想必在linux上写过程序的同学都有分析进程占用多少内存的经历,或者被问到这样的问题——你的程序在运行时占用了多少内存(物理内存)?通常我们可以通过t
helloworld_34035044 helloworld_34035044
1星期前
ERROR 1366 (HY000): Incorrect string value: ‘\xAE\xE8\xB4\xA4\xE4\xB8…
在Linux端部署皕杰报表,安装好mysql库后。在本地dbeaver中运行一个sql文件将数据插入服务器mysql的一个数据库中时出现报错ERROR1366(HY000):Incorrectstringvalue:‘\xAE\xE8\
3A网络 3A网络
2个月前
开发一个不需要重写成 Hive QL 的大数据 SQL 引擎
开发一个不需要重写成HiveQL的大数据SQL引擎学习大数据技术的核心原理,掌握一些高效的思考和思维方式,构建自己的技术知识体系。明白了原理,有时甚至不需要学习,顺着原理就可以推导出各种实现细节。各种知识表象看杂乱无章,若只是学习
helloworld_34035044 helloworld_34035044
5个月前
皕杰报表(关于日期时间时分秒显示不出来)
在使用皕杰报表设计器时,数据据里面是日期型,但当你web预览时候,发现有日期时间类型的数据时分秒显示不出来,只有年月日能显示出来,时分秒显示为0:00:00。1.可以使用tochar解决,数据集用selecttochar(flowdate,"yyyyMMddHH:mm:ss")fromtablename2.也可以把数据库日期类型date改成timestamp