当前位置:  开发笔记 > 编程语言 > 正文

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

如何解决《使用Java将数据添加到数据库》经验,为你挑选了1个好方法。

我试图将图像添加到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定义

将数据字段类型更改为Mediumblob并尝试将140kb图像文件放入数据库后,我收到了不同的错误.

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

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



1> Luke Woodwar..:

尝试使用a MEDIUMBLOB而不是a BLOB. BLOB限制为64KB,而MEDIUMBLOB列可容纳16MB.

请参阅本页的 "字符串类型的存储要求"部分.

推荐阅读
我我檬檬我我186
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有