用jsp对oracle的clob字段进行操作

CLOB一般用来存放超大广西,如果是2进制文件一般用BLOB.
假设col2CLOB:
写操作:

String sql = "insert into tb_commendtemp (col1,col2) values('111',?)";
string s = "
长文本";
StringBufferInputStream sbin = new StringBufferInputStream(s);
PreparedStatement ps = query.getPreStmt(sql);
ps.setAsciiStream(1,sbin,s.length());
int i = ps.executeUpdate();
ps.close();
sbin.close();
if(i>0) ok;
如果是二进制文件就用FileInputStream写进去

读的时候只要
rs.getAsciiStream();
rs.getUnicodeStream();
rs.getBinaryStream();
看它们的名字就知道是得到什么类型的的数据流了.

如果存放的是二进制文件,比如图形,执行文件,压缩文件最好还是blob保险.
写和读也要用二进制流,
DataInputStrean
DatOutputStream.有时用UNICODE的字符流也能行,
不保险.如果是文本,ClobLONG都行.读和写用
BuffreedReader
PrintWriter更方便.



blob:
二进制,如果exe,zip
clob:
单字节码,比如一般的文本文件.
nlob:
多字节码,UTF格式的文件.

如果带格式的文件如果WORD,EXECL等如果要保持格式不被破坏,最好以BLOB
方式,它近似于以byte的原始方式存放,缺点当然是操作时效率低().

操作CLOB,别的可以看我上面的写和读的例子,只要注意把
pstmt.setBinaryStream()改成rs.setAsciiStream();
pstmt.getBinaryStream()改成rs.getBinaryStream();

在从文件读成流的时候用Reader而不要用DataInuputStream

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值