关键字
ORA-12712
适用产品
AnyBackup Express 7.0.9.1
AnyBackup CDM 7.0.9.1
问题描述
在进行 Oracle 实时复制逻辑方案修改目标端数据库字符集时,修改失败,修改界面提示如下错误信息:
ORA-12712: new character set must be a superset of old character set
问题影响
Oracle 实时复制逻辑方案目标端数据库字符集无法修改成功,进而导致 Oracle 实时复制逻辑方案无法正常部署。
问题原因
修改 Oracle 数据库字符集时,修改后的字符集不是数据库原字符集的超集,从而导致修改字符集失败。
Oracle 修改数据库字符集时,要求修改后的字符集是数据库原字符集的超集。
解决方案
为了解决该问题,需要使用强制转换字符集的参数进行修改,具体步骤如下:
1. 查询目标端数据库原字符集,使用如下命令:
select * from nls_database_parameters where parameter in ('NLS_LANGUAGE','NLS_TERRITORY','NLS_CHARACTERSET');
2. 执行 shutdown immediate 命令关闭数据库;
警告:以下步骤需要重启数据库,若目标端数据库存在生产业务,请提前准备停机时间。
3. 启动数据库,并修改数据库参数。按顺序执行如下命令:
startup mount
alter session set sql_trace=true;
alter system set job_queue_processes=0;
alter system set aq_tm_processes=0;
alter database open;
4. 使用强制转换字符集的参数,进行字符集的修改,执行如下命令:
alter database character set INTERNAL_USE AL32UTF8;
注意:示例中源端字符集为:AL32UTF8,INTERNAL_USE 为强制转换参数。
更多信息
Oracle 数据库字符集的超集与子集信息,可参考 Oracle 各版本官方文档,如 Oracle 11g R2 可参考:Subsets and Supersets。
在修改字符集时,若新旧字符集不存在超集-子集的关系,可使用 INTERNAL_USE 参数强制进行转换,但是这种方式可能会导致数据库原本存在的部分数据存在乱码的现象。由于 AnyBackup Oracle 实时复制逻辑方案目标端数据库通常为新部署的环境,不存在生产业务数据,故可使用该方案。若目标端数据库为生产库,则必须选择字符集与源端完全相同,或者字符集为源端数据库字符集的子集的数据库用作目标端方可。