全文检索是用于解决信息快速检索的一个很好的解决方案。
实际工作中偶尔用到,平时没有去深入研究过它的特性。于是不幸的遇到了真实的问题,近期项目上开发同事咨询有关全文检索的功能,正好有需要。于是就把自己以前整理的全文检索使用方法和创建语句发给他,没过一会儿,反馈给我一个问题,记录如下:
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全文检索并不是所有对象都支持,它只对下列类型提供全文检索
CONTEXT
VARCHAR2,
CLOB
BLOB,
CHAR,
BFILE,
XMLType,
URIType
查看表结构,原来这个索引字段是NVARCHAR2,换了个VARCHAR2类型的字段试了一下,没问题。
终于知道了,原来全文索引不支持nvarchar2。
特此记录!