Oracle全文搜索_CatSearch

本文介绍了在Oracle数据库中遇到全文搜索CATSEARCH查询时出现的异常问题,特别是使用CHINESE_VGRAM_LEXER分词器时,如何通过创建自定义偏好和设置前缀索引来解决ORA-29902和DRG-10847错误。同时,讨论了CATSEARCH与CONTEXT索引类型的差异,并指出OracleText对中文支持的条件和限制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Oracle全文索引的查询模板功能可以对在CONTEXT索引上使用CATSEARCH语法,或者在CTXCAT索引上使用CONTAINS语法。

 

Oracle数据库Text单字无法全文搜索---如果项目需要在Oracle数据库下面做全文搜索,你可以选择Oracle自带的全文组件OracleText,从定义索引器(CHINESE_VGRAM_LEXER),建立CTXCAT索引,使用CATSEARCH查询一切都很顺利地进行,但是当加上中文分词后总不经意地抛出异常,提示:


ORA-29902:执行ODCIIndexStart() 例行程序中出错;
ORA-20000:Oracle Text Error;
DRG-10847:CATSEARCH 要求这种类型的查询有前缀索引;

 

现象:我对一个列建了CTXCAT索引

创建索引的语句:
DROP   INDEX   ST_ITEM_ITEM_NAME;
CREATE   INDEX   ST_ITEM_ITEM_NAME
                    ON   ST_ITEM   (ITEM_NAME)
INDEXTYPE   IS   CTXSYS.CTXCAT
PARAMETERS   ( 'LEXER   CTXSYS.CHINESE_VGRAM_LEXER ');

然后使用如下语句查询
select   count(*)   from   ST_ITEM   where   catsearch(name, '我 ',null)> 0
报错:
ORA-29902:   执行   ODCIIndexStart()   例行程序中出错
ORA-20000:   Orac

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值