Navicat向mysql数据库中导入sql文件常见报错问题总结及解决办法

456 阅读1分钟

错误提示1:

Got a packet bigger than ‘max_allowed_packet‘ bytes

分析原因:

从navicat中导入sql文件过大, max_allowed_packet 针对的是一个事务中的一行记录大小,当一行记录超过了限制的大小,将会报错。sql文件中 每次insert完进同一张表的所有数据被称为一个数据包(packet)max_allowed_packet 就是来限制这个的大小的阈值,大于这个值,mysql的I/O连接会关闭,就会报这个错。 

解决办法:

调整 max_allowed_packet 大小(这里设置成:300M):

set global max_allowed_packet = 1024*1024*300;
flush privileges;

查询一下设置是否成功:

select @@global.max_allowed_packet;

重新导入问题解决。

错误提示2:

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

分析原因:

上述报错中可以看出给 datetime 这种类型的字段赋值为 0000-00-00 00:00:00是不被支持的,这是数据库模式的设置问题。

解决办法:

1、查询sql_mode

# 查看当前sql_mode
select @@sql_mode;
# 查看全局sql_mode
select @@global.sql_mode;

2、修改sql_mode(将上述查询到的sql_mode中的NO_ZERO_DATE和NO_ZERO_IN_DATE删除即可)

# 修改全局
set @@global.sql_mode = 'STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';
# 修改当前
set @@sql_mode = 'STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';
# 刷新
flush privileges;

重新导入问题解决。

未完待续.....