如何将 blob 格式的图像保存到 Java 中的 MySQL
How to go about saving an image in blob format to MySQL in Java
出于任务的目的,我必须将图像作为 blob 格式存储到 MySQL(尽管将图像路径存储在数据库中并将图像保存在localcopy 中的一个文件夹)。
到目前为止我已经研究过但找不到任何可以帮助我的答案,这就是我到目前为止所做的
只要点击一个按钮,就会触发:
empdao.insertImage(fis);
图像填充在另一个均匀的侦听器上,如下所示:
static FileInputStream fis = null;
static String path = null;
path = filechooser.getSelectedFile().getAbsolutePath();
File image = new File(path);
fis = new FileInputStream (image);
下面的代码负责将其添加到数据库中。
public void insertImage(FileInputStream fis) throws SQLException {
Connection c = getConnection();
String query = "INSERT INTO Picture (picture) VALUES (?)";
System.out.println(query);
PreparedStatement pstmt = c.prepareStatement(query);
pstmt.setBinaryStream(1, fis);
pstmt.executeUpdate();
c.close();
}
但是问题是我需要它将它转换为 blob,但我不确定该怎么做,有人可以帮助我或指导我如何将所选图像作为 blob 字段存储到 MySQL.
目前,当它把它添加到数据库中时,我在图片列下得到 java.io 文件输入。
假设您在 MySQL 中有一个 table my_picures
,其中 id INT PRIMARY KEY
、name VARCHAR(255),
和 photo BLOB
。
然后你可以使用下面的Java代码插入一张新图片为BLOB
:
public class InsertPictureAsBlob {
public static void main(String[] args) throws Exception, IOException, SQLException {
Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager
.getConnection("jdbc:mysql://localhost/databaseName", "username", "password");
String INSERT_PICTURE = "INSERT INTO my_picures(id, name, photo) VALUES (?, ?, ?)";
conn.setAutoCommit(false);
File file = new File("myPhoto.png");
try (FileInputStream fis = new FileInputStream(file);
PreparedStatement ps = conn.prepareStatement(INSERT_PICTURE)) {
ps.setString(1, "001");
ps.setString(2, "name");
ps.setBinaryStream(3, fis, (int) file.length());
ps.executeUpdate();
conn.commit();
}
}
}
1) 首先,您需要确保在 MySQL 架构中创建了一个 table,并定义了 BLOB 列类型(BLOB、MEDIUMBLOB、LONGBLOB)。查看 MySQL 和 select 中可用的适当大小的 BLOB 列类型。
2) 您将要从使用 Statement 切换到 PreparedStatement。
String query = "INSERT INTO Pictures (Picture) VALUES (?)";
PreparedStatement pstmt = conn.prepareStatement(query);
3) 您目前正在将 FileInputStream 传递给您的方法,因此您只需要在 PreparedStatement 上使用 setBinaryStream 方法。
pstmt.setBinaryStream(1, fis);
4) 然后对PreparedStatement执行executeUpdate()。
pstmt.executeUpdate();
利用原始代码中的异常处理并执行适当的对象清理(数据库连接、准备好的语句),类似于原始代码中的内容。
出于任务的目的,我必须将图像作为 blob 格式存储到 MySQL(尽管将图像路径存储在数据库中并将图像保存在localcopy 中的一个文件夹)。
到目前为止我已经研究过但找不到任何可以帮助我的答案,这就是我到目前为止所做的
只要点击一个按钮,就会触发:
empdao.insertImage(fis);
图像填充在另一个均匀的侦听器上,如下所示:
static FileInputStream fis = null;
static String path = null;
path = filechooser.getSelectedFile().getAbsolutePath();
File image = new File(path);
fis = new FileInputStream (image);
下面的代码负责将其添加到数据库中。
public void insertImage(FileInputStream fis) throws SQLException {
Connection c = getConnection();
String query = "INSERT INTO Picture (picture) VALUES (?)";
System.out.println(query);
PreparedStatement pstmt = c.prepareStatement(query);
pstmt.setBinaryStream(1, fis);
pstmt.executeUpdate();
c.close();
}
但是问题是我需要它将它转换为 blob,但我不确定该怎么做,有人可以帮助我或指导我如何将所选图像作为 blob 字段存储到 MySQL.
目前,当它把它添加到数据库中时,我在图片列下得到 java.io 文件输入。
假设您在 MySQL 中有一个 table my_picures
,其中 id INT PRIMARY KEY
、name VARCHAR(255),
和 photo BLOB
。
然后你可以使用下面的Java代码插入一张新图片为BLOB
:
public class InsertPictureAsBlob {
public static void main(String[] args) throws Exception, IOException, SQLException {
Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager
.getConnection("jdbc:mysql://localhost/databaseName", "username", "password");
String INSERT_PICTURE = "INSERT INTO my_picures(id, name, photo) VALUES (?, ?, ?)";
conn.setAutoCommit(false);
File file = new File("myPhoto.png");
try (FileInputStream fis = new FileInputStream(file);
PreparedStatement ps = conn.prepareStatement(INSERT_PICTURE)) {
ps.setString(1, "001");
ps.setString(2, "name");
ps.setBinaryStream(3, fis, (int) file.length());
ps.executeUpdate();
conn.commit();
}
}
}
1) 首先,您需要确保在 MySQL 架构中创建了一个 table,并定义了 BLOB 列类型(BLOB、MEDIUMBLOB、LONGBLOB)。查看 MySQL 和 select 中可用的适当大小的 BLOB 列类型。
2) 您将要从使用 Statement 切换到 PreparedStatement。
String query = "INSERT INTO Pictures (Picture) VALUES (?)";
PreparedStatement pstmt = conn.prepareStatement(query);
3) 您目前正在将 FileInputStream 传递给您的方法,因此您只需要在 PreparedStatement 上使用 setBinaryStream 方法。
pstmt.setBinaryStream(1, fis);
4) 然后对PreparedStatement执行executeUpdate()。
pstmt.executeUpdate();
利用原始代码中的异常处理并执行适当的对象清理(数据库连接、准备好的语句),类似于原始代码中的内容。