关闭

ORACLE TEXT DATASTORE PREFERENCE(五)

标签: oracleinsertsqltableparametersdatabase
556人阅读 评论(0) 收藏 举报
分类:

这篇文章继续讨论全文索引的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;

未选定行

0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

ArcGIS Data Store 空间数据库的那点儿事

ArcGIS Data Store 是关系数据库管理系统用以存储发布到 Portal for ArcGIS 的要素数据,并使用轻量级、高扩展性的要素数据图层。ArcGIS Data Store...
  • esricd
  • esricd
  • 2016-01-20 14:53
  • 4388

关于如何修改PreferenceFragment中默认的字体颜色和大小

preferenceFragment中修改字体的方法.
  • Major_out
  • Major_out
  • 2016-03-13 11:47
  • 2417

使用 Morphia 和 MongoDB 实现持久化

直接来一个简单的demo:新建一个maven java project(maven-archetype-quickstart):DBHelper:package com.mongo.dao; imp...
  • hejingyuan6
  • hejingyuan6
  • 2016-03-18 18:54
  • 4416

ORACLE TEXT DATASTORE PREFERENCE(六)

这篇文章继续讨论全文索引的DATASTORE属性,介绍NESTED_DATASTORE。 全文索引支持将数据存储在多个列中或存储在主子表中,全文索引还支持将数据存储在嵌套表中...
  • liqfyiyi
  • liqfyiyi
  • 2012-03-31 14:36
  • 526

ORACLE TEXT DATASTORE PREFERENCE(三)

这篇文章继续讨论全文索引的DATASTORE属性,介绍FILE_DATASTORE。 全文索引的对象一般是篇幅较大的文章,除了保存在数据库中的情况,另外一种常见的情况是以文件...
  • liqfyiyi
  • liqfyiyi
  • 2012-03-31 14:26
  • 649

ORACLE TEXT DATASTORE PREFERENCE(四)

这篇文章继续讨论全文索引的DATASTORE属性,介绍URL_DATASTORE。 全文索引可以很方便的索引存储在INTERNET上的信息。在数据库中只需要存储需要索引的文章的URL...
  • liqfyiyi
  • liqfyiyi
  • 2012-03-31 14:27
  • 562

ORACLE TEXT DATASTORE PREFERENCE(一)

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

ORACLE TEXT FILTER PREFERENCE(二)

这篇文章继续介绍全文索引的FILTER属性,介绍Oracle的INSO_FILTER属性。 Oracle的全文索引除了可以支持文本文件外,还可以支持多种文档格式,对于...
  • liqfyiyi
  • liqfyiyi
  • 2012-03-31 14:38
  • 692

ORACLE TEXT FILTER PREFERENCE(四)

这篇文章继续介绍全文索引的FILTER属性,介绍全文索引的PROCEDURE_FILTER属性。 对于一些复杂的需求,Oracle自定义的FILTER可能并不合适,O...
  • liqfyiyi
  • liqfyiyi
  • 2012-03-31 14:59
  • 499

example codes for using Oracle Text to index ms word docx

  • 2016-04-03 09:01
  • 11KB
  • 下载
    个人资料
    • 访问:2344037次
    • 积分:21573
    • 等级:
    • 排名:第397名
    • 原创:158篇
    • 转载:639篇
    • 译文:1篇
    • 评论:49条
    最新评论