通过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);
     

你可能感兴趣的:(通过oracle存储过程的Blob参数上传文件)