前两天朋友找我做一个上传程序,非常简单的一个东西!我没有用过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);