liufengll 2021-06-01 10:14 采纳率: 66.7%
浏览 32
已采纳

java输出流怎么转化为java.sql.blob

   导出excel的时候

OutputStream 转化为blob类型传给前端

  • 写回答

1条回答 默认 最新

  • 小P聊技术 2021-06-01 14:10
    关注
    |
    
    if (conn == null)
    
    throw new SQLException("database connection is not availble!");
    
    String strSQLUpdate= "update demo set blobTest =EMPTY_BLOB() where id=1";
    
    String strSQL= " select blobTest from demo where id=1 for update";
    
    try
    
    {
    PreparedStatement tmpstmt=conn.prepareStatement(strSQLUpdate);
    
    tmpstmt.executeUpdate();
    
    tmpstmt=conn.prepareStatement(strSQL);
    
    ResultSet tmprlt=tmpstmt.executeQuery();
    
    while (tmprlt.next())
    
    {
    java.sql.Blob javaBlob = tmprlt.getBlob(blobField);
    
    oracle.sql.BLOB tmpblob = (oracle.sql.BLOB)javaBlob;
    
    OutputStream os= tmpblob.getBinaryOutputStream();
    
    if(blob != null)
    
    os.write(blob);
    
    os.close();
    
    }
    
    if (oldcommit==true)
    
    {
    conn.commit();
    
    }
    
    }
    
    catch(Exception e)
    
    {
    throw e;
    
    }
    
    finally
    
    {
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

    报告相同问题?

    悬赏问题

    • ¥15 关于PROCEDURE和FUNCTION的问题
    • ¥100 webapi的部署(标签-服务器)
    • ¥20 怎么加快手机软件内部计时的时间(关键词-日期时间)
    • ¥15 C语言除0问题的检测方法
    • ¥15 为什么四分管的内径有的是16mm有的15mm,四分不应该是12.7mm吗
    • ¥15 macos13下 ios交叉编译的问题
    • ¥15 bgz压缩文件怎么打开
    • ¥15 封装dll(引入了pcl的点云设计库)
    • ¥30 关于#开发语言#的问题:我需要在抄板的基础上再抄板抄程序,根据RDA8851CM基础上开发
    • ¥15 oracle 多个括号,怎么删除指定的括号及里面的内容?