我的系统需要从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字段里面的内容取出来转换成输入流?我的操作有什么问题?