利用oracle long類型欄位,插入大文本__oracle

來源:互聯網
上載者:User

我在編寫應用時,需要大量的插入大文本,但是oracle 的clob操作起來比較繁瑣,應此我沒有選擇使用clob,而是使用了oracle以前版本中的long類型[但是long類型有一些限制,在一個表中只能有一個long欄位]。

開始的時候我直接使用insert into table1 values(a,b[long])的方式插入資料庫,但是oracle有些限制一條語句不能超過4000個字元,並報ORA-01704的錯誤。

經過尋找oracle 的文檔找到瞭解決的方法,就是對於long的欄位使用setCharacterStream()方法將String插入資料庫。

代碼:
sql="insert into msg_info values (?,?,?,?[long類型欄位],'C',sysdate,sysdate+"+msgterm+",?)";
pstat1 = conn.prepareStatement(sql);
pstat1.setLong(1, msg_id);
      pstat1.setInt(2, msg_gp_id);
      pstat1.setString(3, msg_title);
      pstat1.setCharacterStream(4,new StringReader(msg_info.toString()),msg_info.length());
conn.commit();
      pstat1.setLong(5, this.upid);

long類型oracle並不推薦,還是採用CLOB才是正路,畢竟現在已是21世紀。
但是CLOB的確用起來非常麻煩,樓主的貼子收藏。

****************************************
使用JDBC存取ORACLE中的LONG類型的資料
****************************************

在ORACLE中可以使用LONG類型儲存大文本,但是操作LONG類型的資料和一般的資料類型不同,下面就舉例說明如何將資料儲存到LONG類型的欄位中.

儲存資料到LONG類型的欄位中,下面將使用一個表進行測試,該表的建立語句如下:

CREATE TABLE T_LONGTEST
(
  ID        INTEGER                             NOT NULL,
  FILENAME  VARCHAR2(100 BYTE),
  CONTENT   LONG
)
LOGGING
NOCACHE
NOPARALLEL;

CREATE UNIQUE INDEX PK_T_LONGTEST ON T_LONGTEST
(ID)
LOGGING
NOPARALLEL;

ALTER TABLE T_LONGTEST ADD (
  CONSTRAINT PK_T_LONGTEST PRIMARY KEY (ID));

插入LONG類型的資料

    BufferedReader bufReader = new BufferedReader(new FileReader(file));
    Integer id = Integer.valueOf(PubFun1.CreateMaxNo(TEST_LONG_ID, 1));
    PreparedStatement pstmt = con.prepareStatement(INSERT_LONG_SQL);
    pstmt.setObject(1, id);
    pstmt.setObject(2, fileName);
    pstmt.setCharacterStream(3, bufReader, (int) length);
    int retValue = pstmt.executeUpdate();
    if (retValue != 1) {
        logger.error("Error on insert value");
    }
    bufReader.close();
    pstmt.close();

INSERT_LONG_SQL的值為:
INSERT INTO T_LONGTEST(ID, FILENAME, CONTENT) VALUES (?, ?, ?)
注意需要使用setCharacterStream方法設定LONG類型的欄位的值.

讀取LONG類型的資料

讀取也需要使用Stream的方式來讀取,下面的代碼片斷說明了讀取LONG類型的欄位的方法.
    PreparedStatement pstmt = con.prepareStatement(QUERY_LONG_COL_SQL);
    pstmt.setObject(1, id);
    ResultSet rs = pstmt.executeQuery();
    if (rs.next()) {
        Reader reader = rs.getCharacterStream(1);
        BufferedReader bufReader = new BufferedReader(reader);
        StringBuffer strBuf = new StringBuffer();
        String line;
        while ((line = bufReader.readLine()) != null) {
            strBuf.append(line);
            strBuf.append("/r/n");
        }
        bufReader.close();
        System.out.println("The content is:" + strBuf.toString());
    }
QUEYR_LONG_COL_SQL的取值為:SELECT CONTENT FROM T_LONGTEST WHERE ID=?

更新LONG類型的資料

更新LONG類型的方法和插入的代碼是一樣的,只是SQL語句不同.下面的代碼斷說明了如何更新LONG類型的資料.(這個例子沒有使用T_LONGTEST表)
    StringReader reader = new StringReader(xmlString);
    pstmt = con
            .prepareStatement(REPORT_MODEL_CONTENT_UPDATE_SQLSTRING);
    pstmt.setCharacterStream(1, reader, xmlString.length());
    pstmt.setInt(2, reportModelId);
    if (pstmt.executeUpdate() == 0) {
        logger
                .error("Error on update");
    }
    reader.close();
REPORT_MODEL_CONTENT_UPDATE_SQLSTRING的取值為:
UPDATE REPORT_MODEL SET CONTENT=? WHERE REPORT_MODEL_ID=?

總結:

從上面的例子可以看到,操作LONG類型的欄位主要是通過CharacterStream,如果是更新資料庫或者將資料插入到資料庫中使用PreparedStatement的setCharacterStream,並且傳入Reader類型的參數和字串的長度.如果是檢索資料庫中的LONG類型的資料,那麼使用getCharacterStream方法,獲得一個Reader類型的對象,然後就可以從其中擷取LONG類型的資料了.

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.