错误提示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;

重新导入问题解决。