Я пытаюсь добавить изображение в поле BLOB в базе данных mysql. Размер изображения будет менее 100 КБ. Однако я сталкиваюсь с проблемами, и мне было интересно, как лучше добавить эти данные в базу данных?
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 и попытки поместить файл изображения размером 140 КБ в базу данных я получил другую ошибку.
com.mysql.jdbc.PacketTooBigException: слишком большой пакет для запроса
Проблема в том, как я пытаюсь добавить данные в базу данных. Должен ли я выбрать другой подход? Если да, то каким образом?