当前位置:   article > 正文

Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column xxxx_[dtf] data transfer started [dtf] 0> getting table

[dtf] data transfer started [dtf] 0> getting tables [dtf] 0> getting views [

背景

  • 从测试环境数据导入到本地数据库报Incorrect datetime value: '0000-00-00 00:00:00',报错详情如下所示。
    [DTF] Data Transfer started
    [DTF] 0> Getting tables
    [DTF] 1> xx: Getting table structure
    [DTF] 1> xxx: Fetching records
    [DTF] 1> xx: Drop table
    [DTF] 1> xx: Create table
    [DTF] 1> xx: Transferring records
    [ERR] 1> INSERT INTO xxx VALUES (xxxx
    [ERR] 1> 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00’ for column ‘create_time’ at row 373
    [DTF] Process terminated

问题分析

  • 为什么会有0000-00-00 00:00:00呢?

官方文档上说明MySQL允许将’0000-00-00’保存为“伪日期”(如果不使用NO_ZERO_DATE SQL模式)。这在某些情况下比使用NULL值更方便(并且数据和索引占用的空间更小)。

解决方案

  • 解决方案就是设置sql_mode,取消NO_ZERO_DATE
  • 我们先来看本地环境的sql_mode设置。使用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
  • 1

在这里插入图片描述

  • 然后再导入,就能成功了,结果如下所示。
    在这里插入图片描述
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/你好赵伟/article/detail/606949
推荐阅读
相关标签
  

闽ICP备14008679号