错误如下:
[ERR] 1292 - Incorrect datetime value: '0000-00-00 00:00:00' for column 'create_at' at row 1
[ERR] 1050 - Table 'a***ny_info' already exists
[ERR] 1062 - Duplicate entry '209' for key 'PRIMARY'
[SQL] Finished with error
解决步骤办法:
1.在MySQL的bin目录下 mysql -h localhost -u root -p ,连接数据库
2.select @@sql_mode; 查看权限,可以看到有NO_ZERO_IN_DATE,NO_ZERO_DATE
比如我的就是
3.去除NO_ZERO_IN_DATE,NO_ZERO_DATE,设置sql_mode的值为ONLY_FULL_GROUP_BY,STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
4.重启MySQL,然后连接数据库查看
select @@sql_mode;
没有NO_ZERO_IN_DATE,NO_ZERO_DATE,
Navicat运行线上转储的SQL文件成功!!!
备注(可不看,只做记录):
贴个图做记录
图1
图2接图1
图3接图2
图4接图3
参考来源:
在navicat上远程连接MySQL,运行存储过程时传入了一个时间参数‘0000-00-00 00:00:00’,发生如下错误
1292 - Incorrect datetime value: '0000-00-00 00:00:00' for column 'targetTime' at row 1
官方文档上说明MySQL允许将’0000-00-00’保存为“伪日期”,但是MySQL有一个NO_ZERO_DATE SQL模式,这个模式默认是打开的,不允许产生伪日期,所以要关掉这个选项。执行SQL语句:
set global sql_mode='STRICT_TRANS_TABLES,STRICT_ALL_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER';
使用show variables like '%sql_mode%';查看关于sql_mode的变量,如果没有NO_ZERO_IN_DATE和NO_ZERO_DATE就说明修改成功