關(guān)于oracle中clob字段查詢慢的問(wèn)題及解決方法
最近在用oracle的過(guò)程中用到了對(duì)blob字段模糊查詢的問(wèn)題,對(duì)oracle來(lái)說(shuō),我并不是高手,找了很多的資料終于能夠查出來(lái)了。
blob字段直接用 select * from table_name where column like ‘%%'
查找的時(shí)候是不能實(shí)現(xiàn)的 ,主要是字段類型不符,就想到了
字段轉(zhuǎn)換成varchar2類型,然后再進(jìn)行查詢
select * from table_name where utl_raw.cast_to_varchar2(column) like ‘%oracle%';
但是卻報(bào)如下的錯(cuò)誤:
在這之后作了修改:
select * from table_name where utl_raw.cast_to_varchar2(DBMS_LOB.SUBSTR(column,2000,1)) like '%oracle%' ;
這樣之后就可以實(shí)現(xiàn)查詢了,但是這樣的查詢總是有些不妥,在網(wǎng)上看到有DBMS_LOB.instr這個(gè)函數(shù),可以直接實(shí)現(xiàn)查找功能。參考http://chabaoo.cn/article/104854.htm中所介紹的具體用法,修改如下:
select * from table_name where dbms_lob.instr(column,utl_raw.cast_to_raw('所要匹配的內(nèi)容'),1,1)<>0;
這樣就可以順利的查找出來(lái)了。
以上只是自己做了個(gè)簡(jiǎn)單的處理,相信肯定有更好的方法,希望大家?guī)兔?,但是感覺(jué)dbms_lob函數(shù)下的方法真的很好用。
oracle clob字段在查詢很慢這是眾所周知的
還是要建立表的索引:
create index search_id on table(字段) indextype is CTXSYS.CONTEXT;
查詢:
select * from table where contains(字段,'內(nèi)容',1)>0;
后續(xù):
這樣查詢結(jié)果很快,但是查出來(lái)的數(shù)據(jù)不是我想要的,具體可能是程序的問(wèn)題,不過(guò)這是解決查詢clob字段慢的一個(gè)方法.希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
Oracle中update和select 關(guān)聯(lián)操作
本文主要向大家介紹了Oracle數(shù)據(jù)庫(kù)之oracle update set select from 關(guān)聯(lián)更新,通過(guò)具體的內(nèi)容向大家展現(xiàn),本文給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧2022-01-01ORACLE 超長(zhǎng)字符串問(wèn)題的解決辦法
這篇文章主要介紹了ORACLE 超長(zhǎng)字符串問(wèn)題的解決辦法,需要的朋友可以參考下2015-10-10Oracle用戶密碼過(guò)期如何修改永不過(guò)期
針對(duì)不同的業(yè)務(wù)場(chǎng)景會(huì)有不一樣的業(yè)務(wù)需求,oracle的用戶密碼,生產(chǎn)環(huán)境肯定需要定期進(jìn)行更換,保證安全性,但是也同樣會(huì)有需求要求oracle用戶的密碼永遠(yuǎn)不過(guò)期,這篇文章主要給大家介紹了關(guān)于Oracle用戶密碼過(guò)期如何修改永不過(guò)期的相關(guān)資料,需要的朋友可以參考下2024-03-03Oracle實(shí)現(xiàn)分頁(yè)查詢的SQL語(yǔ)法匯總
這篇文章主要介紹了Oracle實(shí)現(xiàn)分頁(yè)查詢的SQL語(yǔ)法,非常實(shí)用的功能,需要的朋友可以參考下2014-08-08Oracle安裝TNS_ADMIN環(huán)境變量設(shè)置參考
這篇文章主要為大家介紹了Oracle安裝過(guò)程中關(guān)于TNS_ADMIN環(huán)境變量設(shè)置的參考,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步2021-10-10Oracle通過(guò)時(shí)間(分鐘)計(jì)算有幾天幾小時(shí)幾分鐘的方法
這篇文章主要介紹了Oracle通過(guò)時(shí)間(分鐘)計(jì)算有幾天幾小時(shí)幾分鐘的方法,涉及Oracle時(shí)間操作的技巧,需要的朋友可以參考下2015-03-03Oracle中基于hint的3種執(zhí)行計(jì)劃控制方法詳細(xì)介紹
這篇文章主要介紹了Oracle中基于hint的3種執(zhí)行計(jì)劃控制方法詳細(xì)介紹,它們分別是OUTLINE(大綱)、SQL PROFILE(概要文件)、SQL BASELINE(基線),文中包含大量實(shí)例,需要的朋友可以參考下2014-07-07