亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

oracle數(shù)據(jù)庫(kù)中如何處理clob字段方法介紹

 更新時(shí)間:2012年11月20日 11:48:58   作者:  
在知識(shí)庫(kù)的建立的時(shí)候,用普通VARCHAR2存放文章是顯然不夠的,本文將詳細(xì)將介紹oracle數(shù)據(jù)庫(kù)中如何處理clob字段方法,需要的朋友可以參考下
在知識(shí)庫(kù)的建立的時(shí)候,用普通VARCHAR2存放文章是顯然不夠的,只有區(qū)區(qū)4000的字節(jié),放不了多少字,
而CLOB數(shù)據(jù)類型,則能最多存放8G的數(shù)據(jù)。但是這個(gè)字段處理起來(lái)有比較多的特殊性,記錄一下。
插入:
直接寫(xiě)在SQL里面是不行的,一來(lái)SQL腳本有字符數(shù)限制,而來(lái)文章內(nèi)容包含許多特殊字符,如換行,引號(hào),
之類的東西,很麻煩。網(wǎng)上流行通用做法是先插入一個(gè)空CLOB字段,用empty_clob()方法來(lái)創(chuàng)建空字段,如:
復(fù)制代碼 代碼如下:

INSERT INTO T_TOPIC(TOPIC_ID,TOPIC_CONTENT) VALUES(‘0000001',empty_clob());

然后再用SELECT TOPIC_CONTENT FROM T_TOPIC WHERE TOPIC_ID='0000001'FOR UPDATE的查詢語(yǔ)句,
來(lái)構(gòu)造一個(gè)更新的STATEMENT,在獲取到ResultSet之后,對(duì)CLOB字段進(jìn)行更新。
復(fù)制代碼 代碼如下:

ResultSet rs = pstm.executeQuery();
if(rs.next()){
oracle.sql.CLOB lob =(CLOB)rs.getClob(1);
try {
Writer os = lob.getCharacterOutputStream();
os.write(dr.getField("FLD_CONTENT").asString());
os.flush();
} catch (IOException e) {
e.printStackTrace();
}
}

這個(gè)插入和更新操作要放在事務(wù)中,即獲取到Connection后要設(shè)置setAutoCommit(false);
更新:
更新的時(shí)候也是采用SEELCT … FOR UPDATE方式
也要設(shè)置事務(wù)

讀?。?
復(fù)制代碼 代碼如下:

CLOB clob = (CLOB)rs.getClob("FLD_CONTENT");
Reader reader = clob.getCharacterStream();
StringBuffer sb=new StringBuffer();
char[] cb = new char[1024];
try {
for(int len = reader.read(cb);len>0;len= reader.read(cb)){
sb.append(cb,0,len);
}
} catch (IOException e) {
throw new SQLException("讀取文章內(nèi)容失敗.",e);
}

查詢的特殊性:
有CLOB字段的數(shù)據(jù)表,在SQL語(yǔ)句中不能使用DISTINCT關(guān)鍵字進(jìn)行篩選,即便關(guān)鍵字不用在CLOB字段名前,
實(shí)際上DISTINCT關(guān)鍵字都是對(duì)于SQL中所有字段有效。而CLOB字段是不能進(jìn)行如同LIKE類似的匹配的,所以,
不能進(jìn)行去重復(fù)操作。
兩種解決辦法:
1、在SQL中調(diào)用方法轉(zhuǎn)成VARCHAR2字段后,再DISTINCT,這種方式的局限顯而易見(jiàn)。
2、改變SQL腳本的書(shū)寫(xiě)方式,先查出沒(méi)有CLOB字段的集合,然后在在外層用EXISTS關(guān)鍵字或IN關(guān)鍵字進(jìn)行篩選。
復(fù)制代碼 代碼如下:

//String sqlsel2 = "select jsonbody from db_ps_listcatalog where" +
// " listtype ='sh11' for update";
// String col="jsonbody";

public boolean updateClob(String sql,String col,String buf){
boolean flag=false;
Statement stem=null;
Connection conn=null;
ResultSet rs=null;
Writer wr = null;
try{
conn= dp.getConnection();
conn.setAutoCommit(false);
stem=conn.createStatement();
rs = stem.executeQuery(sql);
if (rs.next()) {
CLOB clob = (CLOB) rs.getClob(col);
java.lang.reflect.Method methodToInvoke = clob.getClass().getMethod(
"getCharacterOutputStream", (Class[]) null);
wr = (Writer) methodToInvoke.invoke(clob, (Object[]) null);
BufferedWriter bw = new BufferedWriter(wr);
bw.write(buf);
bw.flush();
bw.close();
conn.commit();
conn.close();
}
flag=true;
} catch (Exception ex){
try {
conn.rollback();
} catch (SQLException e) {
e.printStackTrace();
}
}
return flag;
}

相關(guān)文章

  • Oracle在PL/SQL中使用存儲(chǔ)過(guò)程

    Oracle在PL/SQL中使用存儲(chǔ)過(guò)程

    這篇文章介紹了Oracle在PL/SQL中使用存儲(chǔ)過(guò)程的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05
  • Oracle數(shù)據(jù)庫(kù)不同損壞級(jí)別的恢復(fù)教程

    Oracle數(shù)據(jù)庫(kù)不同損壞級(jí)別的恢復(fù)教程

    這篇文章主要給大家介紹了關(guān)于Oracle數(shù)據(jù)庫(kù)不同損壞級(jí)別的恢復(fù)教程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Oracle數(shù)據(jù)庫(kù)具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • Oracle?觸發(fā)器trigger使用案例

    Oracle?觸發(fā)器trigger使用案例

    Oracle觸發(fā)器是使用者對(duì)Oracle數(shù)據(jù)庫(kù)的對(duì)象做特定的操作時(shí),觸發(fā)的一段PL/SQL程序代碼器,觸發(fā)器分為語(yǔ)句級(jí)觸發(fā)器和行級(jí)觸發(fā)器,本文通過(guò)案例給大家介紹觸發(fā)器使用,感興趣的朋友跟隨小編一起看看吧
    2022-02-02
  • oracle11數(shù)據(jù)庫(kù)安裝圖文教程

    oracle11數(shù)據(jù)庫(kù)安裝圖文教程

    這篇文章主要為大家詳細(xì)介紹了oracle11數(shù)據(jù)庫(kù)安裝圖文教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • oracle RETURNING 子句使用方法

    oracle RETURNING 子句使用方法

    這篇文章主要介紹了oracle RETURNING 子句使用方法,需要的朋友可以參考下
    2016-02-02
  • win10系統(tǒng)安裝oracle11g時(shí)遇到INS-13001環(huán)境不滿足最低要求解決辦法

    win10系統(tǒng)安裝oracle11g時(shí)遇到INS-13001環(huán)境不滿足最低要求解決辦法

    這篇文章主要介紹了win10系統(tǒng)安裝oracle11g時(shí)遇到INS-13001環(huán)境不滿足最低要求解決辦法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-09-09
  • oracle數(shù)據(jù)庫(kù)關(guān)于索引建立及使用的詳細(xì)介紹

    oracle數(shù)據(jù)庫(kù)關(guān)于索引建立及使用的詳細(xì)介紹

    這篇文章主要介紹了oracle數(shù)據(jù)庫(kù)關(guān)于索引建立及使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • Oracle存儲(chǔ)過(guò)程案例詳解

    Oracle存儲(chǔ)過(guò)程案例詳解

    這篇文章主要介紹了Oracle存儲(chǔ)過(guò)程案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • Oracle 8x監(jiān)控sysdba角色用戶登陸情況

    Oracle 8x監(jiān)控sysdba角色用戶登陸情況

    Oracle 8x監(jiān)控sysdba角色用戶登陸情況...
    2007-03-03
  • oracle更新xml節(jié)點(diǎn)問(wèn)題的一些細(xì)節(jié)

    oracle更新xml節(jié)點(diǎn)問(wèn)題的一些細(xì)節(jié)

    本節(jié)主要介紹了oracle更新xml節(jié)點(diǎn)問(wèn)題的一些細(xì)節(jié),需要的朋友可以參考下
    2014-08-08

最新評(píng)論