a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 數(shù)據(jù)庫 > Oracle > 正文

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

2024-08-29 13:55:57
字體:
供稿:網(wǎng)友
在知識(shí)庫的建立的時(shí)候,用普通VARCHAR2存放文章是顯然不夠的,只有區(qū)區(qū)4000的字節(jié),放不了多少字,
而CLOB數(shù)據(jù)類型,則能最多存放8G的數(shù)據(jù)。但是這個(gè)字段處理起來有比較多的特殊性,記錄一下。
插入:
直接寫在SQL里面是不行的,一來SQL腳本有字符數(shù)限制,而來文章內(nèi)容包含許多特殊字符,如換行,引號(hào),
之類的東西,很麻煩。網(wǎng)上流行通用做法是先插入一個(gè)空CLOB字段,用empty_clob()方法來創(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的查詢語句,
來構(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語句中不能使用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,這種方式的局限顯而易見。
2、改變SQL腳本的書寫方式,先查出沒有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;
}

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 999国产一区二区三区四区 | 综合激情av | 国产精品一区二区久久精品涩爱 | 美女视频一区二区三区 | 亚洲精品一级 | 性高湖久久久久久久久aaaaa | 久久精品免费观看 | 青草免费 | 99亚洲 | 中文字幕二三区不卡 | 久久久久久免费 | 日本不卡一区二区 | 亚洲精品在线免费观看视频 | av在线一区二区三区 | 91精品国产91久久久久久吃药 | 欧美日韩三区 | a级在线 | 日本淫片 | 中文幕av一区二区三区佐山爱 | 久久久精彩视频 | 国产欧美日韩综合 | 能免费看av的网站 | 国内精品在线视频 | 日韩中文字幕网 | 精品久久99 | 亚洲国产日韩欧美 | 99精品久久久久久蜜桃 | 性视频网站免费 | 97国产精品视频人人做人人爱 | 国产精品一区二区av | 亚洲精品久久久久久一区二区 | 精品视频在线免费 | 亚洲国产字幕 | 日日骚| 精品国产一区二区三区四区 | 99久久久精品 | 精品一区二区三区三区 | 亚洲电影一区 | 国产精品久久久久久久免费大片 | 久久99深爱久久99精品 | 成人五月网|