oracle數(shù)據(jù)庫中如何處理clob字段方法介紹建站知識
導(dǎo)讀:1建站知識在知識庫的建立的時候,用普通VARCHAR2存放文章是顯然不夠的,本文將詳細將介紹oracle數(shù)據(jù)庫中如何處理clob字段方法個業(yè)網(wǎng)站建設(shè)公司網(wǎng)站建設(shè)教程。
在知識庫的建立的時候,用普通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字段進行更新。復(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.getCl營銷型網(wǎng)站建設(shè)ob("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)鍵字進行篩選,即便關(guān)鍵字不用在CLOB字段名前, 實際上DISTINCT關(guān)鍵字都是對于SQL網(wǎng)站推廣優(yōu)化seo中所有字段有效。而CLOB字段是不能進行如同LIKE類似的匹配的,所以, 不能進行去重復(fù)操作。 兩種解決辦法: 1、在SQL中調(diào)用方法轉(zhuǎn)成VARCHAR2字段后,再DISTINCT,這種方式的局限顯而易見。 2、改變SQL腳本的書寫方式,先查出沒有CLOB字段的集合,然后在在外層用EXISTS關(guān)鍵字或IN關(guān)鍵字進行篩選。復(fù)制代碼 代碼如下:
//String sqlsel2 = "select jsonbody from db_ps_listcatalog where" + // " listtype ='sh11' for updateseo網(wǎng)站排名優(yōu)化軟件"; // 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)鍵詞標(biāo)簽: 字段 數(shù)據(jù)庫中
聲明: 本文由我的SEOUC技術(shù)文章主頁發(fā)布于:2023-05-23 ,文章oracle數(shù)據(jù)庫中如何處理clob字段方法介紹建站知識主要講述字段,數(shù)據(jù)庫中,oracle數(shù)據(jù)庫中如何處理clob字段方網(wǎng)站建設(shè)源碼以及服務(wù)器配置搭建相關(guān)技術(shù)文章。轉(zhuǎn)載請保留鏈接: http://www.bifwcx.com/article/web_5454.html
為你推薦與oracle數(shù)據(jù)庫中如何處理clob字段方法介紹建站知識相關(guān)的文章
-
通王TWCMS 2.0.3網(wǎng)站模板程序下載
(126)人喜歡 2024-01-15 -
Windows官方原版在哪里下載
(175)人喜歡 2024-01-15 -
WordPress網(wǎng)站模板發(fā)帖標(biāo)題顏色設(shè)置
(131)人喜歡 2024-01-07 -
修改discuz論壇帖子標(biāo)題80字符的長度限制
(249)人喜歡 2024-01-07 -
wordpress程序調(diào)用不帶超鏈接的Tag標(biāo)簽
(234)人喜歡 2024-01-05 -
網(wǎng)站在不同時期需調(diào)整內(nèi)容更新的方向
(112)人喜歡 2023-08-12