oracle全文索引之datastore_5_detail_datastore

jolly10發表於2009-05-14

這篇文章繼續討論全文索引的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/,如需轉載,請註明出處,否則將追究法律責任。

相關文章