这篇文章讨论全文索引DATASTORE的最后一种属性,介绍USER_DATASTORE。

Oracle功能的强大体现在很多方面,除了很多Oracle预定义好的接口以外,Oracle还提供了强大的自定义功能。USER_DATASTORE就是一个例子。如果上面几篇文章介绍的DATASTORE属性无法满足用户的要求,Oracle允许用户自定义一个过程,根据用户的需求来确定被索引的内容。

USER_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

SQL> SELECT * FROM T WHERE CONTAINS(TITLE, 'DOC') > 0;

未选定行

上面这个例子是前面DETAIL_DATASTORE的例子,这个例子中虽然子表中的DOCS列的内容被索引了,但是主表中建立索引的TITLE字段并没有包含在索引中。

如果想要把TITLE内容也包含到索引中,一般的方法是建立一个TITLE列的索引,但是这种方法有几个问题,首先如果在TITLE上建立普通索引,那么就无法对TITLE列进行一些只有CONTEXT索引才支持的高级搜索,且普通索引和全文索引的配合也不是很好。如果在TITLE列上再建立一个全文索引,那么两个全文索引的配合肯定不如一个全文索引效率高,而且,由于同一个字段上不能建立两个全文索引,那么主子表的索引字段还要选择其他的列。显然这种方法问题比较多。

如果要建立一个CTXCAT索引似乎可以很好的解决这个问题,只要将TITLE列的普通索引添加到全文索引的索引组中即可,可惜的是,CTXCAT索引只支持普通的DIRECT_DATASTORE类似的索引。也就是说,CTXCAT索引的内容必须存储在数据库的一张表的一个列里面。

其实想要解决上面提出的那个问题并不算复杂,只需要使用USER_DATASTORE建立一个自定义的存储过程:

SQL> DROP INDEX IND_T_DOCS;

索引已丢弃。

SQL> CREATE OR REPLACE PROCEDURE P_MYSTORE (P_ROWID IN ROWID, P_CLOB IN OUT NOCOPY CLOB) AS
2 BEGIN
3 FOR C_T IN (SELECT ID, AUTHER, TITLE FROM T WHERE ROWID = P_ROWID) LOOP
4 DBMS_LOB.WRITEAPPEND(P_CLOB, LENGTH(C_T.AUTHER) + 1, C_T.AUTHER || ' ');
5 DBMS_LOB.WRITEAPPEND(P_CLOB, LENGTH(C_T.TITLE) + 1, C_T.TITLE || ' ');
6 FOR C_T1 IN (SELECT DOCS FROM T1 WHERE FID = C_T.ID ORDER BY SEQ) LOOP
7 DBMS_LOB.WRITEAPPEND(P_CLOB, LENGTH(C_T1.DOCS) + 1, C_T1.DOCS || ' ');
8 END LOOP;
9 END LOOP;
10 END;
11 /

过程已创建。

SQL> CONN CTXSYS/CTXSYS@YANGTK
已连接。
SQL> CREATE OR REPLACE PROCEDURE P_USERSTORE (P_ROWID IN ROWID, P_CLOB IN OUT NOCOPY CLOB) AS
2 BEGIN
3 YANGTK.P_MYSTORE(P_ROWID, P_CLOB);
4 END;
5 /

过程已创建。

SQL> GRANT EXECUTE ON P_USERSTORE TO YANGTK;

授权成功。

SQL> BEGIN
2 CTX_DDL.CREATE_PREFERENCE('TEST_USER', 'USER_DATASTORE');
3 CTX_DDL.SET_ATTRIBUTE('TEST_USER', 'PROCEDURE', 'P_USERSTORE');
4 CTX_DDL.SET_ATTRIBUTE('TEST_USER', 'OUTPUT_TYPE', 'CLOB');
5 END;
6 /

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_USER');

索引已创建。

SQL> SELECT * FROM T WHERE CONTAINS(TITLE, 'MASTER') > 0;

ID AUTHER TITLE
---------- ------------------------------ ------------------------------
2 YTK DETAIL DATASTORE DOC

SQL> SELECT * FROM T WHERE CONTAINS(TITLE, 'DOC') > 0;

ID AUTHER TITLE
---------- ------------------------------ ------------------------------
2 YTK DETAIL DATASTORE DOC

SQL> SELECT * FROM T WHERE CONTAINS(TITLE, 'YTK') > 0;

ID AUTHER TITLE
---------- ------------------------------ ------------------------------
2 YTK DETAIL DATASTORE DOC
1 YTK DETAIL DATASTORE

通过上面的例子可以看到,使用Oracle提供的接口,即使存储的列的逻辑在复杂,也可以很方便的根据自己的需求来设计索引的存储属性。

ORACLE TEXT DATASTORE PREFERENCE(七)相关推荐

  1. ORACLE TEXT DATASTORE PREFERENCE(二)

    这篇文章继续讨论全文索引的DATASTORE属性,介绍MULTI_COLUMN_DATASTORE. 如果被索引的文章是保存在数据库中,但是内容分布在多个列中,那么可以通过建立一个MULTI_COLU ...

  2. ORACLE TEXT DATASTORE PREFERENCE(一)

    Oracle Text功能十分强大,可是文档上给出的例子总是过于简单,而且可能是为了减少篇幅,不少例子只给出了其中关键的几步,但是对于初学者而言,阅读这样的例子很难对全文索引的创建有一个清晰的了解,而 ...

  3. ORACLE TEXT DATASTORE PREFERENCE(五)

    这篇文章继续讨论全文索引的DATASTORE属性,介绍DETAIL_DATASTORE. 全文索引运行将被索引的数据存储在子表的多条记录中,下面看一个简单的例子: SQL> CREATE TAB ...

  4. ORACLE TEXT DATASTORE PREFERENCE(六)

    这篇文章继续讨论全文索引的DATASTORE属性,介绍NESTED_DATASTORE. 全文索引支持将数据存储在多个列中或存储在主子表中,全文索引还支持将数据存储在嵌套表中.嵌套表的例子和主子表比较 ...

  5. ORACLE TEXT DATASTORE PREFERENCE(四)

    这篇文章继续讨论全文索引的DATASTORE属性,介绍URL_DATASTORE. 全文索引可以很方便的索引存储在INTERNET上的信息.在数据库中只需要存储需要索引的文章的URL就可以了. 由于目 ...

  6. ORACLE TEXT DATASTORE PREFERENCE(三)

    这篇文章继续讨论全文索引的DATASTORE属性,介绍FILE_DATASTORE. 全文索引的对象一般是篇幅较大的文章,除了保存在数据库中的情况,另外一种常见的情况是以文件的形式保存在操作系统中. ...

  7. ORACLE TEXT FILTER PREFERENCE(一)

    介绍完Oracle全文索引的DATASTORE属性,继续介绍Oracle的FILTER属性. Oracle全文索引的FILTER属性主要是针对具有一定格式的文档,Oracle根据FILTER的设定来过 ...

  8. ORACLE TEXT FILTER PREFERENCE(三)

    这篇文章继续介绍全文索引的FILTER属性,介绍对不同类型的数据采用不同类型的FILTER属性的方法. 如果Oracle索引的文档包括多种类型,比如doc文件.html文件.pdf文件.纯文本文件等等 ...

  9. ORACLE TEXT FILTER PREFERENCE(二)

    这篇文章继续介绍全文索引的FILTER属性,介绍Oracle的INSO_FILTER属性. Oracle的全文索引除了可以支持文本文件外,还可以支持多种文档格式,对于这些文档格式,在建立索引的时候需要 ...

最新文章

  1. AI一分钟|苹果无人车可根据乘客情绪调整行车方式;快商通完成近亿元融资
  2. linux 设备驱动程序 过滤,Linux驱动发开,usb设备的probe全过程
  3. Java数据库连接池知识汇总(C3P0+DBCP+Druid)
  4. eureka 其它语言_SpringCloud之Eureka-Go语言中文社区
  5. 2020蓝桥杯省赛---java---A---7(回文日期)
  6. HDU 2089 不要62
  7. 几行Python代码打造自己的磁盘垃圾文件清理器
  8. 谷歌离线地图TMS服务教程
  9. php 在线拍卖系统源码,php拍卖系统,源码
  10. 主板检测卡c5_电脑主板检测卡的代码是什么意思_电脑主板故障诊断检测卡代码汇总(5)_飞翔教程...
  11. python开源代码题库管理_GitHub - gnu-xiaosong/Qu_system: 一款开源免费的题库系统程序,高效,安全,功能强大...
  12. 故障处理 | 网站500,无法打开站点(突然无法打开,代码和服务器没做调整)
  13. [杂记]就《10.30日华为HR体验官胡玲在心声论坛爆料内部HR腐败行为》有感
  14. java基于springboot高校信息资源共享网站系统
  15. dub解析json为构
  16. PyPI 官方仓库遭遇挖矿恶意组件投毒
  17. 【电脑】Wifi模块消失,只剩下飞行模式
  18. w ndows系统启动日志ID,WIN7日志总能看到 特殊登陆 事件ID 4672,是怎么回事?
  19. CC00082.spark——|HadoopSpark.V08|——|Spark.v08|Spark 原理 源码|Spark Context|
  20. TensorFlow 1.x 深度学习秘籍:1~5

热门文章

  1. Dijkstra的理解和实现
  2. Flask之threading.loacl方法
  3. Linux基础知识part3
  4. basepath的作用 (转)
  5. webpack学习笔记--安装
  6. HIVE 在执行大量数据JOIN的时候,容易产生内存不足的情况
  7. .NET自定义获得JSON的方法(System.Runtime.Serialization.Json)
  8. 在一个200*20的bmp中写汉字
  9. 10.8 ss:查看网络状态
  10. oracle isextis,OGG-01052 No recovery is required for target file /ogg/tail_ext/et000000, at...