P
u
r
v
i
s

如何查看并修改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

温馨提示:字符集不要轻易修改,这会对数据库的数据有直接的影响,如果是生产环境,可能会造成不可估计得损失。

posted @ 2022-08-23 20:29  兰purvis  阅读(1976)  评论(0编辑  收藏  举报