mysql: Packet for query is too large 和Data too long for column
2014-09-10 11:46
555 查看
今天在用mysql开发项目的时候,用BLOB字段存储文件二进制流。
一、先是报异常
com.mysql.jdbc.MysqlDataTruncation:
Data truncation: Data too long for column 'title' at row 1
发现上传的文件大于65535字符(mysql在UTF-8编码下汉字也是一个字符,跟oracle一个汉字3个字符不一样)
用 show full fields from table_name; 查询的collation字段可以看到当前表的字符集。
一个BLOB或TEXT列,最大长度为65535(2^16-1)个字符。(0.06 M兆)
MEDIUMBLOB
MEDIUMTEXT
一个BLOB或TEXT列,最大长度为16777215(2^24-1)个字符。 (16M)
LONGBLOB
LONGTEXT
一个BLOB或TEXT列,最大长度为4294967295(2^32-1)个字符。(4G)
最后修改为LONGBLOB 解决第一个问题。
二、max_allowed_packet设置及问题
报的异常:com.mysql.jdbc.PacketTooBigException: Packet for query is too large (1521830 > 1048576). You can change this value on the server
by setting the max_allowed_packet' variable
mysql根据配置文件会限制server接受的数据包大小。
有时候大的插入和更新会被max_allowed_packet 参数限制掉,导致失败。
根据show VARIABLES like '%max_allowed_packet%'; 查询value值(字节)
解决方法,在my.ini里的[mysqld]增加如下部分
[mysqld]
max_allowed_packet=64M
注意,在[client]和[mysql]部分增加无效,那个是客户端读取的参数。
然后一定记住重启MYSQL服务(不是终端),使用net stop mysql + net start mysql 或者 cmd->services.msc重启MYSQL服务,这里仅限于Windows
一、先是报异常
com.mysql.jdbc.MysqlDataTruncation:
Data truncation: Data too long for column 'title' at row 1
发现上传的文件大于65535字符(mysql在UTF-8编码下汉字也是一个字符,跟oracle一个汉字3个字符不一样)
用 show full fields from table_name; 查询的collation字段可以看到当前表的字符集。
一个BLOB或TEXT列,最大长度为65535(2^16-1)个字符。(0.06 M兆)
MEDIUMBLOB
MEDIUMTEXT
一个BLOB或TEXT列,最大长度为16777215(2^24-1)个字符。 (16M)
LONGBLOB
LONGTEXT
一个BLOB或TEXT列,最大长度为4294967295(2^32-1)个字符。(4G)
最后修改为LONGBLOB 解决第一个问题。
二、max_allowed_packet设置及问题
报的异常:com.mysql.jdbc.PacketTooBigException: Packet for query is too large (1521830 > 1048576). You can change this value on the server
by setting the max_allowed_packet' variable
mysql根据配置文件会限制server接受的数据包大小。
有时候大的插入和更新会被max_allowed_packet 参数限制掉,导致失败。
根据show VARIABLES like '%max_allowed_packet%'; 查询value值(字节)
解决方法,在my.ini里的[mysqld]增加如下部分
[mysqld]
max_allowed_packet=64M
注意,在[client]和[mysql]部分增加无效,那个是客户端读取的参数。
然后一定记住重启MYSQL服务(不是终端),使用net stop mysql + net start mysql 或者 cmd->services.msc重启MYSQL服务,这里仅限于Windows
相关文章推荐
- mysql: Packet for query is too large 和Data too long for column
- mysql: Packet for query is too large 和Data too long for column
- mysql5.5异常: java.sql.SQLException: Packet for query is too large (1055975 > 1048576).
- com.mysql.jdbc.PacketTooBigException: Packet for query is too large (2017898 > 1048576)
- Packet for query is too large(mysql写入数据过大)
- Packet for query is too large(mysql写入数据过大)
- Packet for query is too large(mysql写入数据过大)
- Packet for query is too large(mysql)解决
- Packet for query is too large(mysql写入数据过大)
- com.mysql.jdbc.PacketTooBigException: Packet for query is too large (4200044 > 1048576). You can cha
- 解决com.mysql.jdbc.PacketTooBigException: Packet for query is too large (3158064)问题
- Packet for query is too large(mysql写入数据过大
- Packet for query is too large(1767212 > 1048576)mysql在存储图片时提示图片过大
- MySQL中Packet for query is too large (1327736 > 1048576)错误
- mysql5.5异常: java.sql.SQLException: Packet for query is too large (1055975 > 1048576).
- Mysql插入内容过长(Packet for query is too large)
- MYSQL Packet for query is too large
- Mysql插入内容过长(Packet for query is too large)
- MySQL Packet for query is too large
- nested exception is com.mysql.jdbc.PacketTooBigException: Packet for query is too large (1109 > 1024