Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column xxxx
背景
- 从测试环境数据导入到本地数据库报
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 INTOxxx
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
- 然后再导入,就能成功了,结果如下所示。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· 25岁的心里话