如何在Java中将blob格式的图像保存到MySQL中
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了如何在Java中将blob格式的图像保存到MySQL中,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1801字,纯文字阅读大概需要3分钟。
内容图文
![如何在Java中将blob格式的图像保存到MySQL中](/upload/InfoBanner/zyjiaocheng/893/b2a6d0bc48234a42b8297d11388d0c50.jpg)
出于任务的目的,我必须将图像作为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中.
目前,当它将它添加到数据库中时,我在picture列下获得了java.io文件输入.
解决方法:
假设你在MySQL中有一个表my_picures,其中包含id INT PRIMARY KEY,名称为VARCHAR(255)和照片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();
}
}
}
内容总结
以上是互联网集市为您收集整理的如何在Java中将blob格式的图像保存到MySQL中全部内容,希望文章能够帮你解决如何在Java中将blob格式的图像保存到MySQL中所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。