使用Java将数据添加到数据库

时间:2009-03-08 21:34:02

标签: java mysql jdbc

我正在尝试将图像添加到mysql数据库中的BLOB字段。图像尺寸将小于100kb。但是我遇到了问题,并想知道将这些数据添加到数据库的更好方法是什么?

com.mysql.jdbc.MysqlDataTruncation:数据截断:第1行的“数据”列数据太长

PreparedStatement addImage = conn.prepareStatement("INSERT INTO Images (Width, Height, Data) VALUES (?,?,?)",Statement.RETURN_GENERATED_KEYS);

以下是我用于将图像添加到数据库中的方法。

public int addImage(Image image) throws SQLException, IllegalArgumentException
{
    this.addImage.clearParameters();
    byte[] imageData = ImageConverter.convertToBytes(image);
    int width = image.getWidth(null);
    int height = image.getHeight(null);
    if (width == -1 || height == -1)
    {
        throw new IllegalArgumentException("You must load the image first.");
    }



    this.addImage.setInt(1, width);
    this.addImage.setInt(2, height);
    this.addImage.setBytes(3, imageData);
    this.addImage.executeUpdate();

    ResultSet rs = this.addImage.getGeneratedKeys();
    rs.next();

    return rs.getInt(1);
}

SQL Definition for the table

将数据字段类型更改为Mediumblob并尝试将140kb图像文件放入数据库后,我收到了另一个错误。

com.mysql.jdbc.PacketTooBigException:查询包太大

问题是我尝试将数据添加到数据库的方式。我应该采取不同的方法吗?如果是这样的话?

4 个答案:

答案 0 :(得分:6)

尝试使用MEDIUMBLOB代替BLOBBLOB限制为64KB,而MEDIUMBLOB列可容纳16MB。

请参阅this page的“字符串类型的存储要求”部分。

答案 1 :(得分:2)

要处理PacketTooBigException,看起来你需要调整一个配置变量max_allowed_pa​​cket。见http://dev.mysql.com/doc/refman/5.1/en/packet-too-large.html。但是,默认情况下,MySQL 5.1应该可以为您提供高达1MB的问题。您使用的是什么版本的MySQL(服务器和客户端)。

答案 2 :(得分:1)

尝试使用setBlob而不是setBytes

答案 3 :(得分:0)

只需在项目开始时执行以下查询...

SET GLOBAL max_allowed_packet = 1024*1024*number of MB

SET GLOBAL max_allowed_packet = 1024*1024*14

同时阅读this