程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> 關於Oracle數據庫 >> 關於oracle中clob字段查詢慢的問題及解決方法

關於oracle中clob字段查詢慢的問題及解決方法

編輯:關於Oracle數據庫

最近在用oracle的過程中用到了對blob字段模糊查詢的問題,對oracle來說,我並不是高手,找了很多的資料終於能夠查出來了。

blob字段直接用 select * from table_name where column like ‘%%'查找的時候是不能實現的 ,主要是字段類型不符,就想到了

字段轉換成varchar2類型,然後再進行查詢

select * from table_name where utl_raw.cast_to_varchar2(column) like ‘%oracle%'; 

但是卻報如下的錯誤:

在這之後作了修改:

select * from table_name where utl_raw.cast_to_varchar2(DBMS_LOB.SUBSTR(column,2000,1)) like '%oracle%' ;

這樣之後就可以實現查詢了,但是這樣的查詢總是有些不妥,在網上看到有DBMS_LOB.instr這個函數,可以直接實現查找功能。參考http://www.jb51.net/article/104854.htm中所介紹的具體用法,修改如下:

select * from table_name where dbms_lob.instr(column,utl_raw.cast_to_raw('所要匹配的內容'),1,1)<>0;

這樣就可以順利的查找出來了。

以上只是自己做了個簡單的處理,相信肯定有更好的方法,希望大家幫忙,但是感覺dbms_lob函數下的方法真的很好用。

oracle clob字段在查詢很慢這是眾所周知的

還是要建立表的索引:

create index search_id
on table(字段)
indextype is CTXSYS.CONTEXT; 

查詢:

select * from table where contains(字段,'內容',1)>0;

後續:

這樣查詢結果很快,但是查出來的數據不是我想要的,具體可能是程序的問題,不過這是解決查詢clob字段慢的一個方法.希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對網站的支持!

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved