navicat运行db文件_Navicat运行SQL文件出错

在MySQL 5.7版本中,由于NO_ZERO_IN_DATE和NO_ZERO_DATE模式,运行含'0000-00-00'的SQL会报错。解决方法包括:修改sql_mode,移除NO_ZERO_IN_DATE和NO_ZERO_DATE,重启MySQL,确保成功后Navicat能运行SQL文件。
摘要由CSDN通过智能技术生成

错误如下:

[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就说明修改成功

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值