一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫技術(shù)|

服務(wù)器之家 - 數(shù)據(jù)庫 - Oracle - oracle數(shù)據(jù)庫中如何處理clob字段方法介紹

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

2019-11-13 16:06oracle教程網(wǎng) Oracle

在知識庫的建立的時候,用普通VARCHAR2存放文章是顯然不夠的,本文將詳細(xì)將介紹oracle數(shù)據(jù)庫中如何處理clob字段方法,需要的朋友可以參考下

在知識庫的建立的時候,用普通VARCHAR2存放文章是顯然不夠的,只有區(qū)區(qū)4000的字節(jié),放不了多少字, 
而CLOB數(shù)據(jù)類型,則能最多存放8G的數(shù)據(jù)。但是這個字段處理起來有比較多的特殊性,記錄一下。 
插入: 
直接寫在SQL里面是不行的,一來SQL腳本有字符數(shù)限制,而來文章內(nèi)容包含許多特殊字符,如換行,引號, 
之類的東西,很麻煩。網(wǎng)上流行通用做法是先插入一個空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)造一個更新的STATEMENT,在獲取到ResultSet之后,對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(); 


這個插入和更新操作要放在事務(wù)中,即獲取到Connection后要設(shè)置setAutoCommit(false); 
更新: 
更新的時候也是采用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)鍵字都是對于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; 
}

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 91国内精品久久久久影院优播 | 亚洲国产综合自在线另类 | 91欧美国产 | 美女视频ww8888网网 | 91精品国产麻豆国产自产在线 | 国产成人小视频在线观看 | 免费aⅴ片 | 操日日 | 亚洲AV国产福利精品在现观看 | 亚洲精品AV无码永久无码 | 白丝校花被扒开双腿喷水小说 | boobsmilking流奶水野战 | 精品国语国产在线对白 | 精品一区二区三区中文 | 日韩理论片在线看免费观看 | 亚洲视频免费在线观看 | 欧美区日韩区 | 60老妇性xxxxhd | 帅老头恋帅老头同性tv | 韩国男女做性全过程视频 | 国产尤物精品视频 | 欧美va免费大片 | 太紧太深了受不了黑人 | 欧美精品99久久久久久人 | 亚洲精品国产自在现线最新 | 亚洲精品资源在线 | 精品视频日本 | 我的家教老师 | 欧美在线播放一区二区 | 男男同gayxxx | 国产成人咱精品视频免费网站 | 国产精品国产香蕉在线观看网 | 亚洲国产天堂在线观看 | 99国产精品久久久久久久... | 成人au免费视频影院 | 亚洲AV午夜福利精品香蕉麻豆 | 高h折磨调教古代 | 亚洲精品国产福利片 | 小泽玛丽av无码观看 | 四虎永久网址在线观看 | 色怡红院|