Java, 将文件对像写入BLOB字段

以下是java操作oracle数据库.

 

1, 先将文件对像或其他对像转为byte[];

2, 在目标表中insert一条记录,相应的blob字段为empty_blob();

3, 在autoCommit属性为false的前提下, 锁表查询如: select _blob from test for update;

4, 从结果集中取blob字段,得到输出流,并将字符数组写入:

5, 关闭相关对像, 提交connection, 完成.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java 中将达梦数据库中的 BLOB 字段读出并写入文件中的步骤如下: 1. 首先,获取 BLOB 字段的输入流。这可以通过在 JDBC 中使用 ResultSet 和 getBinaryStream() 方法来实现。例如: ``` ResultSet rs = statement.executeQuery("SELECT blob_column FROM my_table WHERE id = 1"); if (rs.next()) { InputStream inputStream = rs.getBinaryStream("blob_column"); // 对 inputStream 进行后续操作 } ``` 2. 创建一个 FileOutputStream 对象,用于将 BLOB 数据写入文件中。例如: ``` FileOutputStream outputStream = new FileOutputStream("my_file"); ``` 3. 使用 Java 的 IO 流 API,将 BLOB 数据从输入流中读取并写入到输出流中。例如: ``` byte[] buffer = new byte[1024]; int bytesRead = 0; while ((bytesRead = inputStream.read(buffer)) != -1) { outputStream.write(buffer, 0, bytesRead); } ``` 4. 最后,关闭输入流和输出流,释放资源。例如: ``` inputStream.close(); outputStream.close(); ``` 完整的代码示例: ``` try { ResultSet rs = statement.executeQuery("SELECT blob_column FROM my_table WHERE id = 1"); if (rs.next()) { InputStream inputStream = rs.getBinaryStream("blob_column"); FileOutputStream outputStream = new FileOutputStream("my_file"); byte[] buffer = new byte[1024]; int bytesRead = 0; while ((bytesRead = inputStream.read(buffer)) != -1) { outputStream.write(buffer, 0, bytesRead); } inputStream.close(); outputStream.close(); } } catch (SQLException | IOException e) { e.printStackTrace(); } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值