Mysql数据库报错:You can change this value on the server by setting the ‘max_allowed_packet‘ variable

这篇博客讨论了在使用Spring框架和jOOQ进行数据库操作时遇到的'Packet for query is too large'错误。问题源于MySQL配置中'max_allowed_packet'参数限制了数据包大小。解决方案包括修改MySQL配置文件,将该值增大到500M并重启服务,或者在命令行临时设置。博主提供了详细的步骤和命令来解决这个问题。
摘要由CSDN通过智能技术生成

今天出现一个mysql插入数据异常如下:
在这里插入图片描述

org.springframework.dao.TransientDataAccessResourceException: jOOQ; SQL [update `knowledge`.`document` set `knowledge`.`document`.`location` = ?, `knowledge`.`document`.`file_type` = ?, `knowledge`.`document`.`parent` = ?, `knowledge`.`document`.`size` = ?, `knowledge`.`document`.`word_count` = ?, `knowledge`.`document`.`words` = ?, `knowledge`.`document`.`append_time` = ?, `knowledge`.`document`.`append_user` = ?, `knowledge`.`document`.`content` = ?, `knowledge`.`document`.`other` = ? where `knowledge`.`document`.`document_name` = ?]; Packet for query is too large (9,015,984 > 999,424). You can change this value on the server by setting the 'max_allowed_packet' variable.; nested exception is com.mysql.cj.jdbc.exceptions.PacketTooBigException: Packet for query is too large (9,015,984 > 999,424). You can change this value on the server by setting the 'max_allowed_packet' variable.
        at org.jooq_3.13.2.MYSQL.debug(Unknown Source)
        at org.springframework.jdbc.support.SQLStateSQLExceptionTranslator.doTranslate(SQLStateSQLExceptionTranslator.java:110)
        at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:72)
        at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:81)
        at org.springframework.jdbc.support.AbstractFallbackSQLExceptionTranslator.translate(AbstractFallbackSQLExceptionTranslator.java:81)
        at org.springframework.boot.autoconfigure.jooq.JooqExceptionTranslator.translate(JooqExceptionTranslator.java:92)
        at org.springframework.boot.autoconfigure.jooq.JooqExceptionTranslator.handle(JooqExceptionTranslator.java:81)
        at org.springframework.boot.autoconfigure.jooq.JooqExceptionTranslator.exception(JooqExceptionTranslator.java:55)

原来mysql根据配置文件会限制server接受的数据包大小。如果一次插入数据库中的数据太大的话就会失败,用命令行查看max_allowed_packet设置的大小

show VARIABLES like '%max_allowed_packet%'

在这里插入图片描述
但实际情况:存入的长度9,015,984 > 999,424所以报错

解决方法

1、修改配置文件(推荐)
在mysql中的my.ini(或my.cnf)文件中修改max_allowed_packet的值500M

max_allowed_packet=524288000

在这里插入图片描述

然后重启mysql就可以,重启mysql方式如下:

#先关闭mysql服务
mysqladmin -uroot -p shutdown
#启动mysql服务
service mysqld start

2、命令行中设置

set global max_allowed_packet = 2*1024*1024*10 

然后退出命令行后再登录查看。但是这个方法没什么用,因为重启mysql服务后这个方法就失效了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值