oracle 读取blob大字段

import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.sql.Blob;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
import org.junit.Test;
public class GetBlobAttachment {
private static String username = "BJWEBWF";
private static String password = "BJWEBWF";
private static Connection conn = null;
private static Statement stmt = null;
private static ResultSet rs = null;
public static Connection getConn() throws Exception {
Class.forName("oracle.jdbc.driver.OracleDriver");
Connection conn = DriverManager
.getConnection("jdbc:oracle:thin:@192.168.0.172:1521:orcl",
username, password);
return conn;
}
public static void closeConn(){
try {
if (stmt != null) {
stmt.close();
}
if (rs != null) {
rs.close();
}
if (conn != null) {
conn.close();
}
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 从数据库中读取blob
* @param dataID
*/
public void getBlob(String dataID){
try {
conn = getConn();
stmt = conn.createStatement();
rs = stmt.executeQuery("select file_name,file_cnt from data_attachment where data_id='"+dataID+"'");
if(rs.next()){
Blob blob = rs.getBlob("file_cnt");
String filename = rs.getString("file_name");
File file = new File("d://"+filename);
FileOutputStream output = new FileOutputStream (file);
InputStream input = blob.getBinaryStream();
byte[] buffer = new byte[1024];
int i = 0;
while ((i = input.read(buffer)) != -1) {
output.write(buffer, 0, i);
}
output.close();
input.close();
}
closeConn();
} catch (Exception e) {
e.printStackTrace();
}
}
@Test
public void getTest(){
getBlob("ff808081286b7e7b01288bf034b10056");
}
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值