MySQL踩坑笔记之Pack for query is too large

it2025-04-04  9

MySQL踩坑日记之Pack for query is too large

引言问题解决办法

引言

今天在做联行号入库时遇到个问题,按照银行名称查询其下所有支行联行号进行入库的时候发现四大行的支行数据无法入库,其他的银行数据都正常。调试半天终于在mysql的日志中发现了猫腻 com.mysql.cj.jdbc.exceptions.PacketTooBigException:Packet for query is too large(1808898 > 1048576). You can change this value on the serevr by setting the 'max _allowed_packet' variable.

问题

什么是max _allowed_packet max_allowed_packet 是我们进行mysql链接时允许的最大传输的值。MySQL根据配置文件会限制Server接受的数据包大小。有时候插入、更新或查询时数据包的大小会受 max_allowed_packet 参数限制,导致操作失败。max_allowed_packet默认的大小是多少? 这个跟自己系统或者安装的MySQL版本有关吧。有人说默认是4M(CentOS 7),还有说是5M的;但是我的默认是1M(windows) 这里的1048576是多少呢?其实就是1M,显然这个数值不合适。

解决办法

既然上述的值太小,name我只要修改到合适的值就可以了。具体值多大根据自己的系统和需求来设定,我这边设置成10M已经够用了,输入以下命令 SET GLOBAL max_allowed_packet = 1024*1024*10 重新连接数据库后输入查询命令SHOW VARIABLES LIKE '%max_allowed_packet%',可以看到值已经修改过来了

最新回复(0)