最近在用oracle的過程中用到了對blob字段模糊查詢的問題,對oracle來說,我并不是高手,找了很多的資料終于能夠查出來了。
blob字段直接用 select * from table_name where column like ‘%%'
查找的時候是不能實現的 ,主要是字段類型不符,就想到了
字段轉換成varchar2類型,然后再進行查詢
1
|
select * from table_name where utl_raw.cast_to_varchar2( column ) like ‘%oracle%'; |
但是卻報如下的錯誤:
在這之后作了修改:
1
|
select * from table_name where utl_raw.cast_to_varchar2(DBMS_LOB.SUBSTR( column ,2000,1)) like '%oracle%' ; |
這樣之后就可以實現查詢了,但是這樣的查詢總是有些不妥,在網上看到有DBMS_LOB.instr這個函數,可以直接實現查找功能。參考中所介紹的具體用法,修改如下:
1
|
select * from table_name where dbms_lob.instr( column ,utl_raw.cast_to_raw( '所要匹配的內容' ),1,1)<>0; |
這樣就可以順利的查找出來了。
以上只是自己做了個簡單的處理,相信肯定有更好的方法,希望大家幫忙,但是感覺dbms_lob函數下的方法真的很好用。
oracle clob字段在查詢很慢這是眾所周知的
還是要建立表的索引:
1
2
3
|
create index search_id on table (字段) indextype is CTXSYS.CONTEXT; |
查詢:
1
|
select * from table where contains (字段, '內容' ,1)>0; |
后續:
這樣查詢結果很快,但是查出來的數據不是我想要的,具體可能是程序的問題,不過這是解決查詢clob字段慢的一個方法.希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對服務器之家網站的支持!
原文鏈接:http://blog.csdn.net/niuhea/article/details/8450130