oracle12712,AnyBackup-Oracle 实时复制逻辑方案修改目标端数据库字符集失败,提示 ORA-12712 错误...

关键字

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');

55554b9548030318c7b33e326898c12d.png

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 实时复制逻辑方案目标端数据库通常为新部署的环境,不存在生产业务数据,故可使用该方案。若目标端数据库为生产库,则必须选择字符集与源端完全相同,或者字符集为源端数据库字符集的子集的数据库用作目标端方可。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值