我在我的MySQL数据库中的BLOB字段有一个问题-当上传大于大约1MB的文件时,我得到一个错误,大于max_allowed_packet是不允许的。

以下是我的尝试:

在MySQL查询浏览器中,我运行了一个像“max_allowed_packet”这样的显示变量,它给了我1048576。

然后我执行查询集全局max_allowed_packet=33554432,然后显示像'max_allowed_packet'这样的变量-它像预期的那样给我33554432。

但是当我重新启动MySQL服务器时,它神奇地回到1048576。我哪里做错了?

额外的问题,是否可以压缩一个BLOB字段?


当前回答

此错误是因为您的数据包含大于设定值。

只需要写下max_allowed_packed=500M 或者你可以计算500*1024k,如果你想用它来代替500M。

现在重新启动MySQL。

其他回答

更改my.ini或~/.my.cnf文件,在[mysqld]或[client]部分中加入一行:

max_allowed_packet=500M

然后重新启动MySQL服务,就完成了。

有关更多信息,请参阅文档。

此错误是因为您的数据包含大于设定值。

只需要写下max_allowed_packed=500M 或者你可以计算500*1024k,如果你想用它来代替500M。

现在重新启动MySQL。

在MYSQL 5.7中,max_allowed_packet最大为1G。如果你想把它设置为4G,它会失败,没有错误和警告。

对于任何在Amazon RDS服务上运行MySQL的人来说,这个更改是通过参数组完成的。您需要创建一个新的PG或使用一个现有的PG(除了默认的只读PG)。

您应该搜索max_allowed_packet参数,更改其值,然后点击保存。

回到您的MySQL实例,如果您创建了一个新的PG,您应该将PG附加到您的实例(您可能需要重新启动)。 如果您更改了已附加到实例的PG,则更改将在不重新引导的情况下应用到已附加该PG的所有实例。

max_allowed_packet变量可以通过运行查询全局设置。

但是,如果您没有在my.ini文件中更改它(如dragon112所建议的那样),则该值将在服务器重新启动时重置,即使您全局地设置了它。

更改每个人允许的最大数据包为1GB,直到服务器重新启动。

SET GLOBAL max_allowed_packet=1073741824;