Oracle数据二进制传输,Oracle数据库插入二进制字段数据

oracle数据库喜欢搞特殊,二进制字段数据不能直接插入,需先再该字段插入oracle函数返回的的初始数据,然后在查询更新该字段。下面以Blob字段类型为例:

1.插入初始数据

Class.forName("oracle.jdbc.driver.OracleDriver");

Connection cn= DriverManager.getConnection("jdbc:oracle:thin:@192.168.0.5:1521:orcl", "qywsbspt", "qywsbspt123999");

cn.setAutoCommit(false);

PreparedStatement pst = cn.prepareStatement("insert into t_uploadfile (file_id,file_content) values (?,EMPTY_BLOB())");

pst.setObject(1,8888);

pst.excuteUpdate();

2.查询更新该字段

pst =   cn.prepareStatement("select  file_content  from t_uploadfile for updatewhere file_id = ? ");

pst.setObject(1,8888);

ResultSet rs = pst.excuteQuery();

BLOB blob = null ; //不是java.sql.Blob,而是oralce.sql.BLOB

if(rs.next())

blob = (BLOB)rs.getBlob(1);  //获取该字段

OutputStream os =blob.getBinaryOutputStream(); //打开操作该字段的流

InputStream is = ...... //获取要插入的二进制文件的输入流

int buffer = -1;

while((buffer = is.read())!=-1){

os.write(buffer);

}

is.close();

os.close();

cn.commit();

rs.close();

pst.close();

cn.close();

原文:http://www.cnblogs.com/cyhj/p/3978845.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值