雷达智富

首页 > 内容 > 程序笔记 > 正文

程序笔记

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

2024-10-05 49

在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是否编辑成功:

然后再次上传文件到数据库,显然这是成功的

更新于:1个月前
赞一波!

文章评论

评论问答