Oracle全文检索方面的研究全.docx

上传人:b****3 文档编号:3745729 上传时间:2023-05-06 格式:DOCX 页数:73 大小:39.77KB
下载 相关 举报
Oracle全文检索方面的研究全.docx_第1页
第1页 / 共73页
Oracle全文检索方面的研究全.docx_第2页
第2页 / 共73页
Oracle全文检索方面的研究全.docx_第3页
第3页 / 共73页
Oracle全文检索方面的研究全.docx_第4页
第4页 / 共73页
Oracle全文检索方面的研究全.docx_第5页
第5页 / 共73页
Oracle全文检索方面的研究全.docx_第6页
第6页 / 共73页
Oracle全文检索方面的研究全.docx_第7页
第7页 / 共73页
Oracle全文检索方面的研究全.docx_第8页
第8页 / 共73页
Oracle全文检索方面的研究全.docx_第9页
第9页 / 共73页
Oracle全文检索方面的研究全.docx_第10页
第10页 / 共73页
Oracle全文检索方面的研究全.docx_第11页
第11页 / 共73页
Oracle全文检索方面的研究全.docx_第12页
第12页 / 共73页
Oracle全文检索方面的研究全.docx_第13页
第13页 / 共73页
Oracle全文检索方面的研究全.docx_第14页
第14页 / 共73页
Oracle全文检索方面的研究全.docx_第15页
第15页 / 共73页
Oracle全文检索方面的研究全.docx_第16页
第16页 / 共73页
Oracle全文检索方面的研究全.docx_第17页
第17页 / 共73页
Oracle全文检索方面的研究全.docx_第18页
第18页 / 共73页
Oracle全文检索方面的研究全.docx_第19页
第19页 / 共73页
Oracle全文检索方面的研究全.docx_第20页
第20页 / 共73页
亲,该文档总共73页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

Oracle全文检索方面的研究全.docx

《Oracle全文检索方面的研究全.docx》由会员分享,可在线阅读,更多相关《Oracle全文检索方面的研究全.docx(73页珍藏版)》请在冰点文库上搜索。

Oracle全文检索方面的研究全.docx

Oracle全文检索方面的研究全

1、准备流程        

 

1.1检查和设置数据库角色

首先检查数据库中是否有CTXSYS用户和CTXAPP脚色。

如果没有这个用户和角色,意味着你的数据库创建时未安装intermedia功能。

你必须修改数据库以安装这项功能。

 默认安装情况下,ctxsys用户是被锁定的,因此要先启用ctxsys的用户。

 

默认ctxsys用户是被锁定的且密码即时失效,所以我们以sys用户进入em,然后修改ctxsys用户的状态和密码。

如图:

 

 

1.2 赋权 

               测试用户以之前已经建好的foo用户为例,以该用户下的T_DOCNEWS为例

先以sys用户dba身份登录,对foo赋resource,connect权限

GRANTresource,connect tofoo;

 

再以ctxsys用户登录并对foo用户赋权

GRANT ctxapp TOfoo;

GRANTexecuteONctxsys.ctx_cls TOfoo;

GRANTexecuteONctxsys.ctx_ddl TOfoo;

GRANTexecuteONctxsys.ctx_doc TOfoo;

GRANTexecuteONctxsys.ctx_outputTOfoo;

GRANTexecuteONctxsys.ctx_queryTOfoo;

GRANTexecuteONctxsys.ctx_report TOfoo;

GRANTexecuteONctxsys.ctx_thes TOfoo;

GRANTexecuteONctxsys.ctx_ulexerTOfoo;

 

查看系统默认的oracletext参数

Selectpre_name,pre_objectfromctx_preferences

 

 

2、OracleText索引原理

Oracletext索引将文本中所有的字符转化成记号(token),如会转化

成www,taobao,com这样的记号。

Oracle10g里面支持四种类型的索引,context,ctxcat,ctxrule,ctxxpath

 

 

 

2.1Context索引

Oracletext索引把全部的word转化成记号,context索引的架构是反向索引(inverted

index),每个记号都映射着包含它自己的文本位置,如单词dog可能会有如下的条目

这表示dog在文档doc1,doc3,doc5中都出现过。

索引建好之后,系统中会自动产生

如下DR$MYINDEX$I,DR$MYINDEX$K,DR$MYINDEX$R,DR$MYINDEX$X,MYTABLE5个表(假设表为

mytable,索引为myindx)。

Dml操作后,context索引不会自动同步,需要利用

ctx_ddl.sync_index手工同步索引。

 

例子:

Createtabledocs(idnumberprimarykey,textvarchar2(200));

Insertintodocsvalues(1,'californiaisastateintheus.');

Insertintodocsvalues(2,'parisisacityinfrance.');

Insertintodocsvalues(3,'franceisineurope.');

Commit;

/

--建立context索引

Createindexidx_docsondocs(text)

indextypeisctxsys.contextparameters

('filterctxsys.null_filtersectiongroupctxsys.html_section_group');

--查询

Columntextformata40;    --字符串截为40位显示。

Selectid,textfromdocswherecontains(text,'france')>0;

 

idtext

-----------------------------------------

3franceisineurope.

2parisisacityinfrance.

--继续插入数据

Insertintodocsvalues(4,'losangelesisacityincalifornia.');

Insertintodocsvalues(5,'mexicocityisbig.');

commit;

Selectid,textfromdocswherecontains(text,'city')>0;--新插入的数据没有查询到

 

idtext

--------------------------------------------

2parisisacityinfrance.

 

 

--索引同步

begin

ctx_ddl.sync_index('idx_docs','2m'); --使用2M同步索引

end;

--查询

Columntextformata50;

Selectid,textfromdocswherecontains(text,'city')>0;--查到数据

idtext

-----------------------------------------------

5mexicocityisbig.

4losangelesisacityincalifornia.

2parisisacityinfrance.

 

 

--or操作符

Selectid,textfromdocswherecontains(text,'cityorstate')>0;

--and操作符

Selectid,textfromdocswherecontains(text,'cityandstate')>0;

或是

Selectid,textfromdocswherecontains(text,'citystate')>0;

 

--score表示得分,分值越高,表示查到的数据越精确

SELECTSCORE

(1),id,textFROMdocsWHERECONTAINS(text,'oracle',1)>0;

Context类型的索引不会自动同步,这需要在进行Dml后,需要手工同步索引。

与context索引相对于的查询操作符为contains

 

2.2Ctxcat索引

用在多列混合查询中

Ctxcat可以利用indexset建立一个索引集,把一些经常与ctxcat查询组合使用的查询列添加到索引集中。

比如你在查询一个商品名时,还需要查询生产日期,价格,描述等,你可可以将这些列添加到索引集中。

oracle将这些查询封装到catsearch操作中,从而提高全文索引的效率。

在一些实时性要求较高的交易上,context的索引不能自动同步显然是个问题,ctxcat则会自动同步索引

 

 

例子:

Createtableauction(Item_idnumber,Titlevarchar2(100),Category_idnumber,Pricenumber,Bid_closedate);

Insertintoauctionvalues(1,'nikoncamera',1,400,'24-oct-2002');

Insertintoauctionvalues(2,'olympuscamera',1,300,'25-oct-2002');

Insertintoauctionvalues(3,'pentaxcamera',1,200,'26-oct-2002');

Insertintoauctionvalues(4,'canoncamera',1,250,'27-oct-2002');

Commit;

 

 

/

--确定你的查询条件(很重要)

--Determinethatallqueriessearchthetitlecolumnforitemdescriptions

--建立索引集

begin

ctx_ddl.create_index_set('auction_iset');

ctx_ddl.add_index('auction_iset','price');/*sub-indexa*/

end;

--建立索引

Createindexauction_titlexonauction(title)indextypeisctxsys.ctxcat

parameters('indexsetauction_iset');

Columntitleformata40;

Selecttitle,pricefromauctionwherecatsearch(title,'camera','orderbyprice')>0;

 

 

Titleprice

-------------------------

Pentaxcamera200

Canoncamera250

Olympuscamera300

Nikoncamera400

 

 

Insertintoauctionvalues(5,'aigocamera',1,10,'27-oct-2002');

Insertintoauctionvalues(6,'lencamera',1,23,'27-oct-2002');

commit;

 

 

 

/

--测试索引是否自动同步

Selecttitle,pricefromauctionwherecatsearch(title,'camera',

'price<=100')>0;

 

Titleprice

-------------------------

aigocamera10

lencamera23

 

 

添加多个子查询到索引集:

 

begin

ctx_ddl.drop_index_set('auction_iset');

ctx_ddl.create_index_set('auction_iset');

ctx_ddl.add_index('auction_iset','price');/*sub-indexA*/

ctx_ddl.add_index('auction_iset','price,bid_close');/*sub-indexB*/

end;

 

dropindexauction_titlex;

 

Createindexauction_titlexonauction(title)indextypeisctxsys.ctxcat

parameters('indexsetauction_iset');

SELECT*FROMauctionWHERECATSEARCH(title,'camera','price=200orderbybid_close')>0;

SELECT*FROMauctionWHERECATSEARCH(title,'camera','orderbyprice,bid_close')>0;

 

任何的Dml操作后,Ctxcat的索引会自动进行同步,不需要手工去执行,与ctxcat索引相对应的查询操作符是catsearch.

语法:

Catsearch(

[schema.]column,

Text_queryvarchar2,

Structured_queryvarchar2,

Returnnumber;

例子:

catsearch(text,'dog','foo>15')

catsearch(text,'dog','bar=''SMITH''')

catsearch(text,'dog','foobetween1and15')

catsearch(text,'dog','foo=1andabc=123')

 

2.3Ctxrule索引

Thefunctionofaclassificationapplicationistoperformsomeactionbasedondocumentcontent.

Theseactionscanincludeassigningacategoryidtoadocumentorsendingthedocumenttoauser.

Theresultisclassificationofadocument.

 

 

 

例子:

Createtablequeries(query_idnumber,query_stringvarchar2(80));

insertintoqueriesvalues(1,'oracle');

insertintoqueriesvalues(2,'larryorellison');

insertintoqueriesvalues(3,'oracleandtext');

insertintoqueriesvalues(4,'marketshare');

commit;

 

Createindexqueryxonqueries(query_string)indextypeisctxsys.ctxrule;

Columnquery_stringformata35;

Selectquery_id,query_stringfromqueries

wherematches(query_string,

'oracleannouncedthatitsmarketshareindatabases

increasedoverthelastyear.')>0;

query_idquery_string

---------------------------------------------

1oracle

4marketshare

 

 

在一句话中建立索引匹配查询

 

2.4Ctxxpath索引

CreatethisindexwhenyouneedtospeedupexistsNode()queriesonanXMLTypecolumn

 

 

 

3.索引的内部处理流程

 

 

3.1Datastore属性

数据检索负责将数据从数据存储(例如web页面、数据库大型对象或本地文件系统)

中取出,然后作为数据流传送到下一个阶段。

Datastore包含的类型有Directdatastore,

Multi_column_datastore,Detail_datastore,File_datastore,Url_datastore,User_datastore,

Nested_datastore。

 

 

 

 

 

 

 

3.1.1.Directdatastore

支持存储数据库中的数据,单列查询.没有attributes属性

支持类型:

char,varchar,varchar2,blob,clob,bfile,orxmltype.

例子:

Createtablemytable(idnumberprimarykey,docsclob);

Insertintomytablevalues(111555,'thistextwillbeindexed');

Insertintomytablevalues(111556,'thisisadirect_datastoreexample');

Commit;

--建立directdatastore

Createindexmyindexonmytable(docs)

indextypeisctxsys.context

parameters('datastorectxsys.default_datastore');

Select*frommytablewherecontains(docs,'text')>0;

 

3.1.2.Multi_column_datastore

适用于索引数据分布在多个列中

thecolumnlistislimitedto500bytes

支持number和date类型,在索引之前会先转化成textt

rawandblobcolumnsaredirectlyconcatenatedasbinarydata.

不支持long,longraw,nchar,andnclob,nestedtable

 

Createtablemytable1(idnumberprimarykey,doc1varchar2(400),doc2clob,doc3

clob);

 

Insertintomytable1values(1,'thistextwillbeindexed','followingexamplecreatesamulti-column','denotesthatthebarcolumn');

Insertintomytable1values(2,'thisisadirect_datastoreexample','usethisdatastorewhenyourtextisstoredinmorethanonecolumn','thesystemconcatenatesthetextcolumns');

Commit;

 

/

--建立multidatastore类型

Begin

Ctx_ddl.create_preference('my_multi','multi_column_datastore');

Ctx_ddl.set_attribute('my_multi','columns','doc1,doc2,doc3');

End;

--建立索引

Createindexidx_mytableonmytable1(doc1)indextypeisctxsys.context

parameters('datastoremy_multi')

Select*frommytable1wherecontains(doc1,'directdatastore')>0;

Select*frommytable1wherecontains(doc1,'examplecreates')>0;

注意:

检索时,检索词对英文,必须是有意义的词,比如,

Select*frommytable1wherecontains(doc1,'morethanonecolumn')>0;

可以查出第二条纪录,但你检索more将没有显示,因为more在那句话中不是有意义的一个词。

 

--只更新从表,看是否能查到更新的信息

Updatemytable1setdoc2='adladlhadadthisdatastorewhenyourtextisstoredtest'where

id=2;

Begin

Ctx_ddl.sync_index('idx_mytable');

End;

Select*frommytable1wherecontains(doc1,'adladlhadad')>0;--没有记录

Updatemytable1setdoc1='thisisadirect_datastoreexample'whereid=2;--更新主表

 

Begin

Ctx_ddl.sync_index('idx_mytable');--同步索引

End;

Select*frommytable1wherecontains(doc1,'adladlhadad')>0;-查到从表的更新

对于多列的全文索引可以建立在任意一列上,但是,在查询时指定的列必须与索引时指定的

列保持一致,只有索引指定的列发生修改,oracle才会认为被索引数据发生了变化,仅修改

其他列而没有修改索引列,即使同步索引也不会将修改同步到索引中.

也就是说,只有更新了索引列,同步索引才能生效,,要更改其他列的同时也要再写一次即可。

在多列中,对任意一列建立索引即可,更新其他列的同时,在update那个列,同步索引一次即可看到效果了。

 

 

 

3.1.3Detail_datastore

适用于主从表查询(原文:

usethedetail_datastoretypefortextstoreddirectlyinthedatabasein

detailtables,withtheindexedtextcolumnlocatedinthemastertable)

因为真正被索引的是从表上的列,选择主表的那个列作为索引并不重要,但是选定之后,查

询条件中就必须指明这个列

主表中的被索引列的内容并没有包含在索引中

DETAIL_DATASTORE属性定义

 

 

 

 

 

 

例子:

createtablemy_master–建立主表

(article_idnumberprimarykey,authorvarchar2(30),titlevarchar2(50),bodyvarchar2

(1));

createtablemy_detail–建立从表

(article_idnumber,seqnumber,textvarchar2(4000),

constraintfr_

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 党团工作 > 入党转正申请

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2