通过oracle存储过程的Blob参数上传文件

前两天朋友找我做一个上传程序,非常简单的一个东西!我没有用过java,现学现卖,反正也是很简单。 不过,中间除了碰到一个东西,在网上查了半天,也没有找到解决的办法!后来才好不容易成功了。我把这个记录下来,希望对用的人有用!

情况是这样,远程服务器是oracle,本地通过调用他的存储存储过程把文件的内容传上去!他的参数是Blob。我查了网上很多的东西,都是这么上传数据的:先在数据表中插入一条记录,Blob字段设置为空对象,然后把这个取得Blob对象,把内容写进去。可是现在只有一个存储过程的接口,不能直接对表操作!下边的是程序的一部分!供大家参考!

    InputStream in = new FileInputStream(szFile);
    int readlength;
    
    oracle.sql.BLOB blob;    
    java.io.OutputStream out;
    
    blob = oracle.sql.BLOB.createTemporary(RConn, false,oracle.sql.BLOB.DURATION_CALL);
    out  = blob.getBinaryOutputStream();
    
    readlength = in.read(b);
    while (readlength != -1) {
     out.write(b, 0, readlength);
     readlength = in.read(b);
    }
    out.flush();
    out.close();

    proc.setObject(13,blob, oracle.jdbc.OracleTypes.BLOB);
    
    proc.execute();
    
    nResult = proc.getInt(16);//返回结果    
    proc.close();
    in.close();  
    oracle.sql.BLOB.freeTemporary(blob);
     

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值