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();
    
        }
    }
    

    }

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

报告相同问题?

悬赏问题

  • ¥15 如何用Labview在myRIO上做LCD显示?(语言-开发语言)
  • ¥15 Vue3地图和异步函数使用
  • ¥15 C++ yoloV5改写遇到的问题
  • ¥20 win11修改中文用户名路径
  • ¥15 win2012磁盘空间不足,c盘正常,d盘无法写入
  • ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计
  • ¥70 PlayWright在Java上连接CDP关联本地Chrome启动失败,貌似是Windows端口转发问题
  • ¥15 帮我写一个c++工程
  • ¥30 Eclipse官网打不开,官网首页进不去,显示无法访问此页面,求解决方法
  • ¥15 关于smbclient 库的使用