weixin_42297455 2008-10-21 15:26
浏览 355
已采纳

用java实现 把一个文件保存到oracle数据库表中

如何把一个文件保存到oracle数据库表中 用java实现

  • 写回答

1条回答 默认 最新

  • Glo Gloria 2008-10-21 16:16
    关注

    public class InsertBlobData {
    Connection con = null;

    /**
     * @param args
     * @throws Exception 
     */
    public static void main(String[] args) throws Exception {
        // TODO Auto-generated method stub
        InsertBlobData data = new InsertBlobData();
        data.insertBlogInfo("002jpg", "sdsdfdf", "2007-02-12", "002.jpg");
    }
    public void insertBlogInfo(String jmzh, String xm, String smsj,
            String fileName) throws Exception {
    

    // try {
    con = ConnectionPoliceFactory.getFactory().getConnection();
    // } catch (ClassNotFoundException e) {
    // // TODO Auto-generated catch block
    // e.printStackTrace();
    // }
    // 处理事务
    boolean defaultCommit = con.getAutoCommit();
    con.setAutoCommit(false);
    Statement st = con.createStatement();
    // 插入一个空对象
    st.executeUpdate("insert into ksren_txxx(jmzh,xm,smsj,txsj) values('"
    + jmzh + "','" + xm + "',to_date('" + smsj
    + "','yyyy-mm-dd'),empty_blob())");
    // 用for update方式锁定数据行
    ResultSet rs = st
    .executeQuery("select txsj from ksren_txxx where jmzh='"
    + jmzh + "' and xm='" + xm + "' for update");
    if (rs.next()) {
    // 得到java.sql.Blob对象,然后Cast为oracle.sql.BLOB
    oracle.sql.BLOB blob = (oracle.sql.BLOB) rs.getBlob(1);
    // 到数据库的输出流
    OutputStream outStream = blob.getBinaryOutputStream();
    // 这里用一个文件模拟输入流
    InputStream fin = new FileInputStream(new File(fileName));
    // 将输入流写到输出流
    byte[] b = new byte[blob.getBufferSize()];
    int len = 0;
    while ((len = fin.read(b)) != -1) {
    outStream.write(b, 0, len);
    // blob.putBytes(1,b);
    }
    // 依次关闭(注意顺序)

            fin.close();
            outStream.flush();
            outStream.close();
            con.commit();
            /* 恢复原提交状态 */
            con.setAutoCommit(defaultCommit);
            con.close();
    
        }
    }
    

    }

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥15 请问Lammps做复合材料拉伸模拟,应力应变曲线问题
  • ¥30 python代码,帮调试
  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥100 Jenkins自动化部署—悬赏100元