ORACEL RAC 字符集
这篇讲的是在Oracle RAC环境下修改数据库字符集,一个容易“踩坑”的实操过程。 作者从一个ZHS16GBK字符集的10g RAC环境出发,目标是将其变更为UTF8。文章核心记录的并非一帆风顺的步骤,而是在执行过程中遇到的典型问题:当尝试直接执行 `alter database character set` 命令时,数据库报出了 `ORA-12720` 错误,提示需要独占模式。这正是RAC环境下修改字符集的关键陷阱。 为解决此问题,作者展示了完整的排查与操作流程:首先需要停止一个节点实例,然后修改 `cluster_database` 参数将集群模式临时改为 `false`,并以独占(`EXCLUSIVE`)模式启动数据库。在确保单节点独占访问后,方才成功执行了字符集变更命令。文章还提到了一个细节操作:手动更新 `props$` 表以同步国家字符集信息,这对于保持数据字典一致性至关重要。最后,再将参数改回集群模式并重启集群。 整个操作对生产环境风险极高,文章通过真实报错和步骤复现,清晰地揭示了RAC架构下字符集变更的特殊限制与必备前提。对于需要执行此操作的DBA来说,这份记录提示了务必在维护窗口内进行、并提前备份的要点。