【Oracle】全文检索不支持NVARCHAR

全文检索是用于解决信息快速检索的一个很好的解决方案。

实际工作中偶尔用到,平时没有去深入研究过它的特性。于是不幸的遇到了真实的问题,近期项目上开发同事咨询有关全文检索的功能,正好有需要。于是就把自己以前整理的全文检索使用方法和创建语句发给他,没过一会儿,反馈给我一个问题,记录如下:

CREATE INDEX idc_MATERIAL ON MD_MATERIAL(material_num) indextype IS ctxsys.context parameters('lexer my_lexer')
错误报告 -
ORA-29855: 执行 ODCIINDEXCREATE 例行程序时出错
ORA-20000: Oracle Text 错误:
DRG-11135: 功能并非广泛可用
ORA-06512: 在 "CTXSYS.DRUE", line 186
ORA-06512: 在 "CTXSYS.TEXTINDEXMETHODS", line 320
29855. 00000 -  "error occurred in the execution of ODCIINDEXCREATE routine"
*Cause:    Failed to successfully execute the ODCIIndexCreate routine.
*Action:   Check to see if the routine has been coded correctly.

原文

exec ctx_ddl.create_preference ('my_lexer', 'BASIC_LEXER'); 
EXEC ctx_ddl.set_attribute('my_lexer ','printjoins','_-'); 
CREATE INDEX idc_MATERIAL ON MD_MATERIAL(MATERIAL_NUM) indextype IS ctxsys.context parameters('lexer my_lexer');

一开始以为是权限问题和操作用户问题,尝试执行如下:

alter user ctxsys account unlock;
GRANT EXECUTE ON CTXSYS.CTX_DDL TO MSTDATA;

切换到目标用户执行,问题依旧,

查阅文档,原来oracle全文检索并不是所有对象都支持,它只对下列类型提供全文检索

CONTEXTVARCHAR2,CLOBBLOB,CHAR,BFILE,XMLType,URIType

查看表结构,原来这个索引字段是NVARCHAR2,换了个VARCHAR2类型的字段试了一下,没问题。

终于知道了,原来全文索引不支持nvarchar2。

特此记录!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值