oracle全文索引之datastore_5_detail_datastore
這篇文章繼續討論全文索引的DATASTORE屬性,介紹DETAIL_DATASTORE。
[@more@]
全文索引執行將被索引的資料儲存在子表的多條記錄中,下面看一個簡單的例子:
SQL> CREATE TABLE T (ID NUMBER PRIMARY KEY, AUTHER VARCHAR2(30), TITLE VARCHAR2(30));
Table created.
SQL> CREATE TABLE T1 (ID NUMBER PRIMARY KEY, FID NUMBER, SEQ NUMBER, DOCS VARCHAR2(1000),
2 CONSTRAINT FK_T1_FID FOREIGN KEY (FID) REFERENCES T(ID))
3 ;
Table created.
SQL> INSERT INTO T VALUES (1, 'YTK', 'DETAIL DATASTORE');
1 row created.
SQL> INSERT INTO T1 VALUES (1, 1, 1, 'THIS IS A DETAIL DATASTORE EXAMPLE');
1 row created.
SQL> INSERT INTO T1 VALUES (2, 1, 2, 'THE CONTEXT IS STORE IN DETAIL TABLES');
1 row created.
SQL> INSERT INTO T VALUES (2, 'YTK', 'DETAIL DATASTORE DOC');
1 row created.
SQL> INSERT INTO T1 VALUES (3, 2, 1, 'USE THE DETAIL_DATASTORE TYPE FOR TEXT');
1 row created.
SQL> INSERT INTO T1 VALUES (4, 2, 2, 'STORED DEIRECTLY IN THE DATABASE IN DETAIL TABLES');
1 row created.
SQL> INSERT INTO T1 VALUES (5, 2, 3, 'WITH INDEXED TEXT COLUMN');
1 row created.
SQL> INSERT INTO T1 VALUES (6, 2, 4, 'LOCATED IN THE MASTER TABLE');
1 row created.
SQL> commit;
Commit complete.
SQL> BEGIN
2 CTX_DDL.CREATE_PREFERENCE('TEST_DETAIL', 'DETAIL_DATASTORE');
3 CTX_DDL.SET_ATTRIBUTE('TEST_DETAIL', 'BINARY', 'TRUE');
4 CTX_DDL.SET_ATTRIBUTE('TEST_DETAIL', 'DETAIL_TABLE', 'T1');
5 CTX_DDL.SET_ATTRIBUTE('TEST_DETAIL', 'DETAIL_KEY', 'FID');
6 CTX_DDL.SET_ATTRIBUTE('TEST_DETAIL', 'DETAIL_LINENO', 'SEQ');
7 CTX_DDL.SET_ATTRIBUTE('TEST_DETAIL', 'DETAIL_TEXT', 'DOCS');
8 END;
9 /
PL/SQL procedure successfully completed.
SQL> CREATE INDEX IND_T_DOCS ON T (TITLE) INDEXTYPE IS CTXSYS.CONTEXT
2 PARAMETERS ('DATASTORE TEST_DETAIL');
Index created.
SQL> SELECT * FROM T WHERE CONTAINS(TITLE, 'MASTER') > 0;
ID AUTHER TITLE
---------- ------------------------------ ------------------------------
2 YTK DETAIL DATASTORE DOC
同樣,建立這種型別的索引必須要建立一個PREFERENCE,並設定主子表的一些屬性。BINARY屬性設定在明細記錄
後是否新增換行。DETAIL_TABLE屬性設定子表名稱。DETAIL_KEY屬性設定子表的外來鍵列。DETAIL_LINENO設定子
表中文件的順序。DETAIL_TEXT設定為索引的欄位名稱。
建立好PERFERENCE,並設定屬性後,建立索引就很簡單了,需要注意的是,由於真正被索引的列是子表上的列,
因此選擇主表中那個列作為索引列並不重要。但是選定之後,以後的查詢必須指明這個列。而且,如果子表中被
索引的文件內容發生變化,也必須透過修改索引列來使Oracle認識到被索引資料發生修改。
最後說明一點,由於使用了DETAIL_DATASTORE選項,主表中的被索引列的內容並沒有包含在全文索引中。
SQL> SELECT * FROM T WHERE CONTAINS(TITLE, 'DOC') > 0;
no rows selected
各引數的說明如下:
Attribute Attribute Value
binary
Specify TRUE for Oracle to add no newline character after each detail row.
Specify FALSE for Oracle to add a newline character (n) after each detail row automatically.
detail_table
Specify name of detail table (OWNER.TABLE if necessary)
detail_key
Specify name of detail table foreign key column(s)
detail_lineno
Specify name of detail table sequence column.
detail_text
Specify name of detail table text column.
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/271283/viewspace-1022088/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- oracle全文索引之STORAGE PREFERENCEOracle索引
- oracle全文索引之WORDLIST PREFERENCEOracle索引
- oracle全文索引之幾個關鍵表Oracle索引
- oracle全文索引之commit與DML操作Oracle索引MIT
- oracle全文索引之如何實現查詢Oracle索引
- oracle全文索引之STOPLIST_4_MULTI_STOPLISTOracle索引
- oracle全文索引之STOPLIST_3_DEFAULT_STOPLISTOracle索引
- oracle全文索引之STOPLIST_2_EMPTY_STOPLISTOracle索引
- oracle全文索引之STOPLIST_1_BASIC_STOPLISTOracle索引
- oracle全文索引之LEXER_4_MULTI_LEXEROracle索引
- oracle全文索引之LEXER_3_DEFAULT_LEXEROracle索引
- oracle全文索引之LEXER_2_CHINESE_LEXEROracle索引
- oracle全文索引之LEXER_1_BASIC_LEXEROracle索引
- oracle全文索引之FILTER_4_PROCEDURE_FILTEROracle索引Filter
- oracle全文索引之FILTER_3_FORMAT_COLUMNOracle索引FilterORM
- oracle全文索引之FILTER_1_NULL_FILTEROracle索引FilterNull
- oracle全文索引之datastore_6_NESTED_DATASTOREOracle索引AST
- oracle全文索引之datastore_4_URL_DATASTOREOracle索引AST
- oracle全文索引之datastore_3_FILE_DATASTOREOracle索引AST
- oracle全文索引之datastore_1_DIRECT_DATASTOREOracle索引AST
- Oracle:全文索引Oracle索引
- oracle全文索引之配置全文檢索環境Oracle索引
- oracle 之全文索引表的分割槽交換案例Oracle索引
- oracle全文索引之About_INDEX_THEMES操作Oracle索引Index
- oracle全文索引之STOPLIST_ CTXCAT 索引_INDEX SETOracle索引Index
- oracle全文索引之datastore_2_MULTI_COLUMN_DATASTOREOracle索引AST
- Oracle的全文索引Oracle索引
- ZT oracle全文索引Oracle索引
- oracle全文索引之SECTION GROUP_6_PATH_SECTION_GROUPOracle索引
- oracle全文索引之SECTION GROUP_5_AUTO_SECTION_GROUPOracle索引
- oracle全文索引之SECTION GROUP_4_XML_SECTION_GROUPOracle索引XML
- oracle全文索引之SECTION GROUP_3_HTML_SECTION_GROUPOracle索引HTML
- oracle全文索引之SECTION GROUP_2_BASIC_SECTION_GROUPOracle索引
- oracle全文索引之SECTION GROUP_1_NULL_SECTION_GROUPOracle索引Null
- oracle全文索引之FILTER_2_INSO_FILTEROracle索引Filter
- oracle 全文索引的配置Oracle索引
- MongoDB之索引(全文索引)MongoDB索引
- oracle全文索引之同步和優化索引做了什麼Oracle索引優化