设置MySQL储存文件大小的限制

在servlet上传图片到MySQL数据库过程中,MySQL存储文件大小是有限制的,比如数据库只能存储1M文件的大小,上传的文件就不能超过这个限制,如果超过限制就会报以下的错误信息:
故障现象:数据存储文件的时候报ERROR: Packet for query is too large (1869728 > 1048576). You can change this value on the server by setting the max_allowed_packet’ variable.
在这里插入图片描述
在这里插入图片描述

以上的问题就是上传文件的大小已经超过数据库限制的大小,导致数据库存储不了文件,所以这个时候我们需要重新设置数据库存储文件的大小:
从报错看是 mysql的 max_allowed_packet参数值设置太少了,用show VARIABLES like ‘%max_allowed_packet%’;查看,显示的是1M(1024x1024),这当然就有问题了,超过1M就存不了
在这里插入图片描述
MySQL根据配置文件会限制server接受的数据包大小。有时候大的插入和更新会被max_allowed_packet 参数限制掉,导致失败,要重新设置参数可以在MySQL命令行中运行:
set global max_allowed_packet = 2x1024x1024x10
在这里插入图片描述
然后关闭掉这此MySQL Server链接,再重新连接。再次用show VARIABLES like ‘%max_allowed_packet%’
查看下max_allowed_packet是否编辑成功:
在这里插入图片描述
然后再次上传文件到数据库,显然这是成功的
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值