【异常】 com.mysql.jdbc.PacketTooBigException: Packet for query is too large (1354 > 1024)

问题

Caused by: com.mysql.jdbc.PacketTooBigException: 
Packet for query is too large (1354 > 1024).
You can change this value on the server by setting the
max_allowed_packet' variable

分析

根据问题就能得知数据包的太大,无法接收。
mysql会根据配置限制server接受的数据包大小,尤其当大批量的数据插入和更新就会因为max_allowed_packet参数限制掉,导致失败。
查看mysql的max_allowed_packet参数

show VARIABLES like '%max_allowed_packet%';

一般默认配置是1M,根据需要调整大小就好了
调整方式有两种

方式一

修改mysql的配置文件
例如修改为:
max_allowed_packet=10M
修改完成后重新启动MySQL的服务

方式二

进入mysql server
在mysql 命令行中运行
set global max_allowed_packet = 1024*1024*10
然后关闭掉这此mysql server链接,再进入。
show VARIABLES like ‘%max_allowed_packet%’;
查看下max_allowed_packet是否编辑成功

【总结】

    之前做批量插入的时候并没有遇到过这样的问题,还是业务量不够造成,所以以后做批量插入或者更新的时候注意将数据在系统内部做一个转换,例如每500条插入一次,诸如此类的操作。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Mandy_i

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值