如何查看并修改Oracle编码
1、查看Oracle数据库编码:
SQL> select * from nls_database_parameters where parameter ='NLS_CHARACTERSET';
执行结果(来源于props$,表示数据库的字符集):
PARAMETER
--------------------
VALUE
--------------------
NLS_CHARACTERSET
AL32UTF8
2、查看Oracle客户端编码:
SQL> select * from nls_instance_parameters where parameter='NLS_LANGUAGE';
执行结果(来源于v$parameter,表示客户端的字符集的设置,可能是参数文件,环境变量或者是注册表会话字符集环境):
PARAMETER
--------------------
VALUE
--------------------
NLS_LANGUAGE
SIMPLIFIED CHINESE
3、查看Oracle当前会话编码(来源于v$nls_parameters,应该是会话的环境变量或者是alter session完成,如果会话没有特殊的设置,将与nls_instance_parameters一致):
select * from nls_session_parameters
4、如何修改Oracle字符集(当下字符集是AL32UTF8,修改为ZHS16GBK):
① 以sysdba的身份登录Oracle上去 conn /as sysdba
② 关闭数据库shutdown immediate;
③ 以mount打来数据库,startup mount
④ 设置session
SQL> ALTER SYSTEM ENABLE RESTRICTED SESSION; SQL> ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0; SQL> ALTER SYSTEM SET AQ_TM_PROCESSES=0;
⑤ 启动数据库
ALTER DATABASE OPEN;
⑥ 修改字符集
ALTER DATABASE CHARACTER SET ZHS16GBK; --这会可能会报错,提示我们的字符集:新字符集必须为旧字符集的超集,这时我们可以跳过超集的检查做更改:
ALTER DATABASE CHARACTER SET INTERNAL_USE ZHS16GBK; --这条语句就可以了,TERNAL_USE提供的帮助就会使oracle绕过了子集与超集的验证,这条语句和上面的语句内部操作时完全相同的。
⑦ 关闭,重新启动
SQL> shutdown immediate; SQL> startup
温馨提示:字符集不要轻易修改,这会对数据库的数据有直接的影响,如果是生产环境,可能会造成不可估计得损失。
本文作者:兰purvis
本文链接:https://www.cnblogs.com/purvis/p/16617699.html
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步