如何解决Oracle 9i到11g迁移KOREAN_LEXER的问题?

Aym*_*ric 5 oracle oracle9i oracle11g

我目前正在将Oracle 9i数据库(*.dmp文件)迁移到Oracle 11g数据库.为此,我使用exp和imp Oracle实用程序命令行:

exp USERID=<user>/<password>@<database> FILE=<path> OWNER=<owner>
Run Code Online (Sandbox Code Playgroud)

然后我创建一个skeleton.sql文件,它将创建表,索引表和最后的索引.

imp <user>/<password>@<database> FILE=<path> INDEXFILE="<path>\skeleton.sql" FROMUSER=<fromuser> TOUSER=<touser>
Run Code Online (Sandbox Code Playgroud)

在此迁移过程中,我能够正确导入大部分数据,当然,从一个数据库到另一个数据库,表空间保持不变,以避免任何冲突.

但问题来了.在Oracle 11g中,不再支持KOREAN_LEXER,而是必须使用KOREAN_MORPH_LEXER.为此,我执行以下SQL命令:

call ctx_ddl.create_preference('korean_lexer','korean_morph_lexer');
call ctx_ddl.add_sub_lexer('global_lexer','korean','korean_lexer',null);
Run Code Online (Sandbox Code Playgroud)

然后我导入skeleton.sql文件,以便在导入之前注入所需的数据:

sqlplus <user>/<password>@<database> @<path>\skeleton.sql
Run Code Online (Sandbox Code Playgroud)

表和索引表的创建顺利进行,直到我为每个创建的150多个索引收到以下错误:

CREATE INDEX "<schema>"."WORKORDER_NDX16" ON "WORKORDER"
ERROR at line 1 :
ORA-29855: error occurred in the execution of ODCIINDEXCREATE routine
ORA-20000: Oracle Text error:
DRG-10502: WORKORDER_NDX16 index does not exist
DRG-13201: KOREAN_LEXER is no longer supported
ORA-06512: at "CTXSYS.DRUE", line 160
ORA-06512: at "CTXSYS.TEXTINDEXMETHODS", line 366
Run Code Online (Sandbox Code Playgroud)

索引仍然创建,此消息​​只是一个警告.我尝试重建任何破坏的索引:

ALTER index WORKORDER_NDX16 REBUILD;
Run Code Online (Sandbox Code Playgroud)

哪次再次给我以下错误:

SQL Error : ORA-29874: warning in the execution of ODCIINDEXCREATE routine
ORA-29960: ligne 1, 
DRG-10595: failure on ALTER INDEX WORKORDER_NDX16
DRG-50857: oracle error in drixmd.PurgeKGL
ORA-20000: Oracle Text error:
DRG-13201: KOREAN_LEXER is no longer supported
ORA-30576: ConText Option dictionary loading error
DRG-50610: internal error: kglpurge []
29874. 00000 -  "warning in the execution of ODCIINDEXALTER routine"
*Cause:    A waring was returned from the ODCIIndexAlter routine.
*Action:   Check to see if the routine has been coded correctly
           Check the user defined warning log tables for greater details.
Run Code Online (Sandbox Code Playgroud)

在我的skeleton.sql文件中,在每个索引的创建下,每种语言都有以下几行:

ctxsys.driimp.set_object('LEXER','MULTI_LEXER',12);
...
ctxsys.driimp.set_sub_value('SUB_LEXER','8', NULL, NULL,'KO:KOREAN_LEXER:');
...
Run Code Online (Sandbox Code Playgroud)

到目前为止,我不知道该怎么做,这似乎是一个简单的问题要解决,但我的dba技能太低,不能自己做.

如果有人能帮助我,我会非常感激!

谢谢.

Jos*_*ber 2

看起来您的数据库正在使用 Oracle Text 索引,这与普通索引不同。您是否完全遵循 Oracle Note 300172.1(KOREAN_LEXER Lexer 类型的废弃)?下面提到了这段代码,这可能会有所帮助。

ALTER INDEX <[schema.]index> REBUILD 
PARAMETERS('REPLACE LEXER ko_morph_lexer [MEMORY <size>]');
Run Code Online (Sandbox Code Playgroud)

如果一切都失败了,也许可以考虑尝试将数据迁移到 Oracle 10g 数据库并korean_morph_lexer在 10g 中完成。如果可行,那么将其从 10g 移动到 11g(或 12c)将是一个简单的数据泵任务。