ORACLE TEXT FILTER PREFERENCE(三)
這篇文章繼續介紹全文索引的FILTER屬性,介紹對不同類型的數據采用不同類型的FILTER屬性的方法。
如果Oracle索引的文檔包括多種類型,比如doc文件、html文件、pdf文件、純文本文件等等。由于Oracle不建議對HTML、XML和純文本文件使用INSO_FILTER,因此沒有一個統一適用的FILTER屬性適合所有的文檔。
Oracle提供了一種FORMAT列的方法,通過設置FORMAT列的內容可以通知Oracle建立何種FILTER甚至是不建立索引。
下面看一個簡單的例子:
SQL> CREATE TABLE T (ID NUMBER, TYPE VARCHAR2(6), DOCS VARCHAR2(100));
表已創建。
SQL> INSERT INTO T VALUES (1, 'BINARY', 'Oracle920 Text Application Developer''s Guide.pdf');
已創建?1 行。
SQL> INSERT INTO T VALUES (2, 'TEXT', 'readme.txt');
已創建?1 行。
SQL> INSERT INTO T VALUES (3, 'IGNORE', 'Oracle920 Text Reference.pdf');
已創建?1 行。
SQL> COMMIT;
提交完成。
SQL> CONN CTXSYS/CTXSYS@YANGTK
已連接。
SQL> BEGIN
2 CTX_DDL.CREATE_PREFERENCE('TEST_FILE', 'FILE_DATASTORE');
3 CTX_DDL.SET_ATTRIBUTE('TEST_FILE', 'PATH', 'D:databaseoracleoracle docoracle 9i;D:databaseoracleoracle docdocOracle920B10501_01');
4 END;
5 /
PL/SQL 過程已成功完成。
SQL> CONN YANGTK/YANGTK@YANGTK
已連接。
SQL> CREATE INDEX IND_T_DOCS ON T (DOCS) INDEXTYPE IS CTXSYS.CONTEXT
2 PARAMETERS ('DATASTORE CTXSYS.TEST_FILE FILTER CTXSYS.INSO_FILTER FORMAT COLUMN TYPE');
索引已創建。
SQL> SELECT * FROM T WHERE CONTAINS(DOCS, 'ORACLE') > 0;
ID TYPE DOCS
---------- ------ --------------------------------------------------
2 TEXT readme.txt
1 BINARY Oracle920 Text Application Developer's Guide.pdf
設置COLUMN列的值,設置為BINARY的文檔使用INST_FILTER,設置為TEXT的文檔
總結
以上是生活随笔為你收集整理的ORACLE TEXT FILTER PREFERENCE(三)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: ORACLE TEXT FILTER P
- 下一篇: ORACLE TEXT FILTER P