ORACLE TEXT FILTER PREFERENCE(二)

标签: oracle filter sql parameters application file
715人阅读 评论(0) 收藏 举报
分类:

这篇文章继续介绍全文索引的FILTER属性,介绍Oracle的INSO_FILTER属性。


Oracle的全文索引除了可以支持文本文件外,还可以支持多种文档格式,对于这些文档格式,在建立索引的时候需要指定INSO_FILTER参数,使用这个过滤参数,Oracle的全文索引可以识别绝大部分的常见文档,比如:word、pdf等。

下面看一个索引文档的例子:

SQL> CREATE TABLE T (ID NUMBER, DOCS VARCHAR2(1000));

表已创建。

SQL> INSERT INTO T VALUES (1, 'Oracle920 Text Application Developer''s Guide.pdf');

已创建 1 行。

SQL> INSERT INTO T VALUES (2, '35697_bommarito.doc');

已创建 1 行。

SQL> COMMIT;

提交完成。

SQL> CONN CTXSYS/CTXSYS@YANGTK
已连接。
SQL> BEGIN
2 CTX_DDL.CREATE_PREFERENCE('TEST_FILE', 'FILE_DATASTORE');
3 CTX_DDL.SET_ATTRIBUTE('TEST_FILE', 'PATH', 'D:databaseoracleoracle docoracle 9i;D:databaseoracleoracle doc');
4 END;
5 /

PL/SQL 过程已成功完成。

SQL> CONN YANGTK/YANGTK@YANGTK
已连接。
SQL> CREATE INDEX IND_T_DOCS ON T (DOCS) INDEXTYPE IS CTXSYS.CONTEXT
2 PARAMETERS ('DATASTORE CTXSYS.TEST_FILE FILTER CTXSYS.INSO_FILTER');

索引已创建。

SQL> SELECT * FROM T WHERE CONTAINS(DOCS, 'ORACLE') > 0;

ID DOCS
---------- ------------------------------------------------------------
2 35697_bommarito.doc
1 Oracle920 Text Application Developer's Guide.pdf

FILTER的默认值并不是一成不变的,这个默认值会受索引字段类型和DATASTORE的类型的影响。在上一篇文章中的测试中,对于存储在数据库中的VARCHAR2、CHAR和CLOB字段中的数据,Oracle自动选择了NULL_FILLER。在这里DATASTORE的属性为FILE_DATASTORE,则Oracle会默认选择INSO_FILTER作为默认值。

下面看具体的例子:

SQL> DROP INDEX IND_T_DOCS;

索引已丢弃。

SQL> CREATE INDEX IND_T_DOCS ON T (DOCS) INDEXTYPE IS CTXSYS.CONTEXT
2 PARAMETERS ('DATASTORE CTXSYS.TEST_FILE FILTER CTXSYS.NULL_FILTER');

索引已创建。

SQL> SELECT * FROM T WHERE CONTAINS(DOCS, 'ORACLE') > 0;

未选定行

SQL> DROP INDEX IND_T_DOCS;

索引已丢弃。

SQL> CREATE INDEX IND_T_DOCS ON T (DOCS) INDEXTYPE IS CTXSYS.CONTEXT
2 PARAMETERS ('DATASTORE CTXSYS.TEST_FILE');

索引已创建。

SQL> SELECT * FROM T WHERE CONTAINS(DOCS, 'ORACLE') > 0;

ID DOCS
---------- ------------------------------------------------------------
2 35697_bommarito.doc
1 Oracle920 Text Application Developer's Guide.pdf

查看评论

ORACLE TEXT FILTER PREFERENCE(一)

介绍完Oracle全文索引的DATASTORE属性,继续介绍Oracle的FILTER属性。 Oracle全文索引的FILTER属性主要是针对具有一定格式的文档,Oracle根据FILTER...
  • liqfyiyi
  • liqfyiyi
  • 2012-03-31 14:37:39
  • 944

ORACLE TEXT FILTER PREFERENCE(四)

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

ORACLE TEXT FILTER PREFERENCE(三)

这篇文章继续介绍全文索引的FILTER属性,介绍对不同类型的数据采用不同类型的FILTER属性的方法。 如果Oracle索引的文档包括多种类型,比如doc文件、htm...
  • liqfyiyi
  • liqfyiyi
  • 2012-03-31 14:39:10
  • 561

ORACLE TEXT LEXER PREFERENCE(二)

介绍完Oracle全文索引的BASIC_LEXER属性,这篇介绍Oracle中文语法属性CHINESE_LEXER和CHINESE_VGRAM_LEXER。 Oracle全文索引的B...
  • liqfyiyi
  • liqfyiyi
  • 2012-03-31 15:03:54
  • 728

ORACLE TEXT DATASTORE PREFERENCE(二)

这篇文章继续讨论全文索引的DATASTORE属性,介绍MULTI_COLUMN_DATASTORE。 如果被索引的文章是保存在数据库中,但是内容分布在多个列中,那么可以通过建立一个M...
  • liqfyiyi
  • liqfyiyi
  • 2012-03-31 14:25:04
  • 1071

oracle text全文检索的开发和相关文档

  • 2009年01月15日 16:54
  • 198KB
  • 下载

[Android--Tool]开发前eclipse preference的一些简单设置

问题描述:Android开发编译器官方是用的eclipse,功能很强大。对于eclipse的使用不是很熟悉,于是参照了一个网上的视频教程对偏好进行了设置,主要是字体,行号显示。     偏好设置:在工...
  • suxiang198
  • suxiang198
  • 2015-07-11 00:23:04
  • 859

自定义Preference中设置其中TextView,等widget方法

在custom 的preference中可以添加textview等widget,直接通过findviewbyid找到某一widget并设置其text是不行的。方法是: 在custom prefere...
  • autumn_xl
  • autumn_xl
  • 2016-05-23 15:45:58
  • 595

ORACLE TEXT DATASTORE PREFERENCE(一)

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

ORACLE TEXT DATASTORE PREFERENCE(四)

这篇文章继续讨论全文索引的DATASTORE属性,介绍URL_DATASTORE。 全文索引可以很方便的索引存储在INTERNET上的信息。在数据库中只需要存储需要索引的文章的URL...
  • liqfyiyi
  • liqfyiyi
  • 2012-03-31 14:27:16
  • 599
    个人资料
    持之以恒
    等级:
    访问量: 252万+
    积分: 2万+
    排名: 391
    最新评论