oracle 存储过程 存储 blob,穿越oracle存储过程的Blob参数上传文件

前两天朋友找我做一个上传过程,极其容易的一个东西!我未曾用过java,现学现卖,反正也是很容易。

不过,其中除非碰到一个东西,在网上查了半晌,也未曾找遍地理的措施!尔后才好不轻率获胜了。我把这个登记下来,渴望对用的人有用!

情形是这么,长途服务器是oracle,本地穿越调用他的存贮存储过程把文件的内容传上去!他的参数是Blob。我查了网上许多的东西,都是这么上传数据的:先在数据表中插入一条登记,Blob字段设置为空对象,然后把这个获得Blob对象,胰岛素泵把内容写进去。然而目前只有一个存储过程的接口,不能直接对表垄断sh.shofan.cn!下边的是过程的一局部!供大家参看!

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

你大约就没可能在书本上遇就任何足以揭示“面向对象”之必需性的问题,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值