Java如何储存二进制流于数据库? (java 如何将二进制的流保存到数据库)

在实际开发中,我们有时需要将二进制流存储到数据库中,例如将图片、视频等文件储存到数据库中。Java提供了多种储存二进制流的方式,下面将介绍如何利用Java进行二进制流储存于数据库中的操作。

1.利用JDBC API储存二进制流

JDBC API提供了储存二进制流的方法,可以通过执行SQL语句完成二进制流的储存操作。

以下是Java通过JDBC API储存二进制流的样例代码:

“`java

try{

String url = “jdbc:mysql://localhost:3306/test”;

String user = “root”;

String password = “blog”;

Connection connection = DriverManager.getConnection(url, user, password);

String sql = “INSERT INTO image(id, data) VALUES(?, ?)”;

PreparedStatement statement = connection.prepareStatement(sql);

statement.setInt(1, 1);

File file = new File(“test.png”);

FileInputStream inputStream = new FileInputStream(file);

statement.setBinaryStream(2, inputStream, inputStream.avlable());

int result = statement.executeUpdate();

System.out.println(result);

statement.close();

connection.close();

}catch(Exception e){

e.printStackTrace();

}

“`

在该样例中,我们先创建了一个新的数据连接`connection`,然后用`PreparedStatement`对象来执行插入语句。在插入语句中,通过`setInt`方法设置ID,通过`setBinaryStream`方法设置二进制流,并执行SQL语句。

2. 利用Hibernate 储存二进制流

如果你使用Hibernate ORM框架,那么可以很方便地储存二进制流到数据库中。Hibernate API内置了对二进制流数据类型的支持,只需要在实体类中添加`@Lob`注解即可。

以下是Hibernate ORM框架储存二进制流的样例代码:

“`java

@Entity

@Table(name = “image”)

public class Image{

@Id

private int id;

@Lob

private byte[] data;

// getters and setters

}

“`

在该实体类中,通过`@Lob`注解将属性`data`设置成二进制流类型,可以让Hibernate自动将其映射到数据库中的BLOB类型。这种方法不需要编写SQL语句,插入数据时直接通过`session.save`方法实现即可。

3. 利用Spring JDBC 储存二进制流

Spring JDBC也提供了支持二进制流储存的API,通过JdbcTemplate对象可以完成二进制流与数据库的交互。

以下是Spring JDBC中储存二进制流的样例代码:

“`java

@Autowired

JdbcTemplate jdbcTemplate;

public void updateAvatar(int userId, InputStream avatar){

jdbcTemplate.update(

“UPDATE user SET avatar=? WHERE id=?”,

new Object[] { avatar, userId },

new int[] { Types.BLOB, Types.INTEGER }

);

}

“`

在该样例中,我们通过`jdbcTemplate.update`更新语句将二进制流写入数据库中,在更新参数中需要指定类型为BLOB。这种方法比较简单,并且不需要编写SQL语句。

以上就是Java如何储存二进制流于数据库的操作,可以根据实际情况选择适合自己的方法。无论是JDBC API、Hibernate ORM框架还是Spring JDBC,都提供了方便快捷的API让我们可以很容易地储存数据到数据库中。深入理解这些API的使用方式,能够大大提高Java在实际项目中的开发效率。

相关问题拓展阅读:

Java怎么做到把图片转换成流存入数据库,然后怎么再把图片显示出来。

oracle如下

数据库中提供了两种字段类型 Blob 和 Clob 用于存储大型字符串或二进制数据(如图片)。

Blob 采用单数散字节存储,适合保存二进制数据,如图片文件。

Clob 采用多字节存储,适合保存大型文本数据。

首先创建一橘枝个空 Blob/Clob 字段,再从这个空 Blob/Clob字段获取游标,例如下面的代码:

PreparedStatement ps = conn.prepareStatement( ” insert into PICTURE(image,resume) values(?,?) ” );

// 通过oralce.sql.BLOB/CLOB.empty_lob()构造空Blob/Clob对象

ps.setBlob( 1 ,oracle.sql.BLOB.empty_lob());

ps.setClob( 2 ,oracle.sql.CLOB.empty_lob());

ps.excuteUpdate();

ps.close();

// 再次对读出Blob/Clob句柄

ps = conn.prepareStatement( ” select image,resume from PICTURE where id=? for update ” );

ps.setInt( 1 , 100 );

ResultSet rs = ps.executeQuery();

rs.next();

oracle.sql.BLOB imgBlob = (oracle.sql.BLOB)rs.getBlob( 1 );

oracle.sql.CLOB resClob = (oracle.sql.CLOB)rs.getClob( 2 );

// 将二进制数据写入Blob

FileInputStream inStream = new FileInputStream( ” ” );

OutputStream outStream = imgBlob.getBinaryOutputStream();

byte buf = new byte ;

int len;

while (len = inStream.read(buf) > 0 ) {

outStream.write(buf, 0 ,len);

}

inStream.close();

outStream.cloese();

// 将字符串写入Clob

resClob.putString( 1 , “圆毕敏 this is a clob ” );

// 再将Blob/Clob字段更新到数据库

ps = conn.prepareStatement( ” update PICTURE set image=? and resume=? where id=? ” );

ps.setBlob( 1 ,imgBlob);

ps.setClob( 2 ,resClob);

ps.setInt( 3 , 100 );

ps.executeUpdate();

ps.close();

java : 一个excel文件以二进制的形式存在数据库中 如何将它导出并下载到本地

从数据库中得到Blob/Clob,然蠢桐察后得到带茄InputStream,直轮孙接给response.getOutputStream() 输出就可以

关于java 如何将二进制的流保存到数据库的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


数据运维技术 » Java如何储存二进制流于数据库? (java 如何将二进制的流保存到数据库)