我正在尝试将一张图片添加到MySQL数据库的BLOB字段中。这张图片的大小将小于100kb。但是,我遇到了问题,想知道有什么更好的方法将这些数据添加到数据库中?
com.mysql.jdbc.MysqlDataTruncation: 数据截断:在第1行,“Data”列的数据太长。
以下是我正在使用的将图像添加到数据库中的方法。
com.mysql.jdbc.MysqlDataTruncation: 数据截断:在第1行,“Data”列的数据太长。
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);
}
将数据字段类型更改为Mediumblob后,尝试将一个大小为140kb的图像文件放入数据库时,我收到了不同的错误。
com.mysql.jdbc.PacketTooBigException:查询数据包太大
问题出在我尝试向数据库添加数据的方式上吗?我应该采取不同的方法吗?如果是,应该用哪种方法呢?