jdbc操作oracle的BLOB字段时遇到的问题!!

yutan_313 2010-04-26 10:43:06
我的系统需要从oracle数据库中取文件,文件是用BLOB字段形式存放的。取出来以后,打印blob.length()是有长度的,但是我做了InputStream input = blob.getBinaryStream();以后,input里面没有内容,打印input.avilable()为0。代码如下:
····
ResultSet rs = statement.executeQuery("select content from t_file t where t.title='***'");
if(rs.next()){
InputStream input = null;
Blob blob = rs.getBlob(1);
if(blob!=null){
System.out.println(blob.length());//此时是有长度的
input = blob.getBinaryStream();
System.out.println(input.avilable());//此时打印出来的是0,也就是说,blob里面的内容没有转换成输入流
}
/** 开始我以为是java.sql.Blob与oracle的BLOB字段之间没有转换造成的,于是我加了转换,但是还是没有解决问题:
BLOB blob = (BLOB)rs.getBlob(1);
if(blob!=null){
System.out.println(blob.length());//此时是有长度的
input = blob.getBinaryStream();
System.out.println(input.avilable());//此时打印出来的是0,
}
**/
}
····

我想请问各位,使用jdbc的话,要怎么将BLOB字段里面的内容取出来转换成输入流?我的操作有什么问题?
...全文
107 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
yutan_313 2010-04-26
  • 打赏
  • 举报
回复
顶起来啊,怎么没有人回答啊!
yutan_313 2010-04-26
  • 打赏
  • 举报
回复
用了,也不行
Johnson_v1 2010-04-26
  • 打赏
  • 举报
回复
你直接用InputStream is = rs.getBinaryStream(1)试试

67,513

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧