ORACLE TEXT DATASTORE PREFERENCE(五)
這篇文章繼續討論全文索引的DATASTORE屬性,介紹DETAIL_DATASTORE。
全文索引運行將被索引的數據存儲在子表的多條記錄中,下面看一個簡單的例子:
SQL> CREATE TABLE T (ID NUMBER PRIMARY KEY, AUTHER VARCHAR2(30), TITLE VARCHAR2(30));
表已創建。
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));
表已創建。
SQL> INSERT INTO T VALUES (1, 'YTK', 'DETAIL DATASTORE');
已創建?1 行。
SQL> INSERT INTO T1 VALUES (1, 1, 1, 'THIS IS A DETAIL DATASTORE EXAMPLE');
已創建?1 行。
SQL> INSERT INTO T1 VALUES (2, 1, 2, 'THE CONTEXT IS STORE IN DETAIL TABLES');
已創建?1 行。
SQL> INSERT INTO T VALUES (2, 'YTK', 'DETAIL DATASTORE DOC');
已創建?1 行。
SQL> INSERT INTO T1 VALUES (3, 2, 1, 'USE THE DETAIL_DATASTORE TYPE FOR TEXT');
已創建?1 行。
SQL> INSERT INTO T1 VALUES (4, 2, 2, 'STORED DEIRECTLY IN THE DATABASE IN DETAIL TABLES');
已創建?1 行。
SQL> INSERT INTO T1 VALUES (5, 2, 3, 'WITH INDEXED TEXT COLUMN');
已創建?1 行。
SQL> INSERT INTO T1 VALUES (6, 2, 4, 'LOCATED IN THE MASTER TABLE');
已創建?1 行。
SQL> COMMIT;
提交完成。
SQL> CONN CTXSYS/CTXSYS@YANGTK
已連接。
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 過程已成功完成。
SQL> CONN YANGTK/YANGTK@YANGTK
已連接。
SQL> CREATE INDEX IND_T_DOCS ON T (TITLE) INDEXTYPE IS CTXSYS.CONTEXT
2 PARAMETERS ('DATASTORE CTXSYS.TEST_DETAIL');
索引已創建。
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;
未選定行
總結
以上是生活随笔為你收集整理的ORACLE TEXT DATASTORE PREFERENCE(五)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: ORACLE TEXT DATASTOR
- 下一篇: ORACLE TEXT DATASTOR