<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    tbwshc

    Oracle 的Blob使用小結

    Oracle 的Blob

    Oracle的Lobs的流處理方式與Long等對象的Stream方式不一樣,沒有Long的諸多限制;只要保持連接,就能通過blob對象正確讀取對象。
    有兩種方式可以讀取Blob:
    1.直接使用ps.getBinaryStream()的方法得到流對象
    2.使用getBlob得到blob,然后通過blob的方法提供的getBinaryStream(),getBytes() 訪問blob的數據。
    這兩種方法都可以在rs.close之后正確獲取數據。(在spring 的JdbcTemplet環境下,該rs理論上被JdbcTemplet自動關閉;從數據庫連接來看,連接也正確關閉了)。

    使用Blob的好處是,按需獲取Blob對象。而且可以多次通過blob.getBinaryStream得到對象。且Blob返回的對象可以使用mark/reset方法反復訪問。且連接狀態正常。
    使用blob得到InputStream,可以調用close()接口,也可以不調用該接口,tb在連接關閉時將自動關閉該連接。最好調用close()釋放資源。

    c3p0的setBlob(pos,InputStream)接口不能正常工作。

    寫入或更新Blob時,可以使用ps.setBinaryStream();調用此接口后,in對象到文件尾(在把stream寫入blob后,不能要再調用in.close()關閉文件,否則報錯)。
    也可以使用setBlob(pos,Blob)方法來寫入或更新Blob字段;但是注意的是,無論是以blob還是blob.getBinaryStream的方式,都不能自己更新自己,否則死鎖。

    使用spring讀取blob的示例程序:
                String sql = "select photo from my_photoes where id='test2' and photo is not null and rownum<2 ";
    BLOB blob= (BLOB) simpleDao.queryForObject(sql,Blob.class);       
    InputStream in = blob.getBinaryStream();
    String filename = "./test/dao/pic" + 1+ ".gif";
    BufferedOutputStream out = new BufferedOutputStream(new FileOutputStream(filename));

                /* 需oracle的BLOB支持。效率可能會高些,但是空間上會有些浪費
    byte[] b = new byte[blob.getBufferSize()];                //blob必須為oracle.sql.BLOB時才可調getBufferSize方法; 與java.sql.Blob區別。
    System.out.println("bufferSize="+b.length);            //32k左右,用這種方式讀取文件會有一點空間的浪費。
    int len=-1;
    while ((len = in.read(b)) != -1) {
    out.write(b);
    }
                */

                /*   純jdbc方法:
                    nt b;
         while ((b = in.read()) != -1) {
        out.write(b);
         }
                */

    in.close();
    out.close();



    http://hi.baidu.com/hexiong/blog/item/34d7b2b7f9b3e8f431add103.html  其他參考
    BLOB處理遇到的問題:
    1.用spring的模板類來處理blob時,遇到大文件時,流會異常關閉。解決辦法,使用oracle的本地連接來獲取blob流,如下:
        public boolean queryForBlobStream(String sql,OutputStream fout)
        {
            boolean flag=true;
            try {
                Connection conn = DataSourceUtils.getConnection(getJdbcTemplate().getDataSource());
                conn.setAutoCommit(false);                        //此部分ms能提高性能
                Statement st = conn.createStatement();
                ResultSet rs = st.executeQuery(sql);
                if (rs.next()) {
                    java.sql.Blob blob = rs.getBlob(1);
                    InputStream ins = blob.getBinaryStream();
                    //輸出到文件
                    //下面將BLOB數據寫入文件
                    byte[] b = new byte[1024];
                    int len = 0;
                    while ((len = ins.read(b)) != -1) {
                        fout.write(b, 0, len);
                    }
                    //依次關閉
                    fout.close();
                    ins.close();
                }
                conn.commit();
                rs.close();             //maybe not nessesary
                st.close();             //maybe not nessesary
                conn.close();
            } catch (IOException ex) {
                flag=false;
            } catch (SQLException ex) {
                flag=false;
            }
            return flag;
        }
    2.如果把blob對象放到記錄的字段中,在web開發中,通過blob.getBinaryStream()只能獲得一次blob流,第二次調用同一對象的blob流會得到null流。
    且在這種方式下,不能使用in.close()關閉流。

    posted on 2012-07-17 15:34 chen11-1 閱讀(17851) 評論(0)  編輯  收藏 所屬分類: oracle

    主站蜘蛛池模板: 亚洲专区中文字幕| xxxxx做受大片在线观看免费| 国产乱人免费视频| 国产高潮久久免费观看| 亚洲一区二区三区四区在线观看| 欧美a级在线现免费观看| 日本高清免费中文在线看| 亚洲精品成人av在线| 日韩一区二区三区免费体验| 在线观看人成视频免费无遮挡| 亚洲午夜久久久精品电影院| 亚洲乱码中文字幕综合234| 无码av免费网站| 美景之屋4在线未删减免费| 麻豆亚洲AV永久无码精品久久| 国产精品无码一区二区三区免费 | 亚洲AV无码乱码在线观看富二代| 日本人的色道免费网站| 亚州**色毛片免费观看| 亚洲欧洲国产视频| 亚洲精品无码成人片久久| 四色在线精品免费观看| 小日子的在线观看免费| 免费在线观看自拍性爱视频| 亚洲日韩乱码中文无码蜜桃臀| 久久国产成人亚洲精品影院| 成人毛片18岁女人毛片免费看| 成人无码WWW免费视频| 无码天堂亚洲国产AV| 亚洲AV成人无码天堂| 亚洲AV无码精品色午夜在线观看| 亚洲Av无码乱码在线播放| 在线观看免费宅男视频| 久久夜色精品国产亚洲AV动态图| 亚洲精品成人片在线观看| 在线jlzzjlzz免费播放| 97免费人妻无码视频| 最近免费最新高清中文字幕韩国| 日本高清不卡aⅴ免费网站| 免费夜色污私人影院网站电影| 亚洲国产AV一区二区三区四区|