修改Oracle字符集为UTF-8解决中文乱码问题

 更新时间:2023年12月02日 09:51:43   作者:芽孢八叠球菌  
这篇文章主要介绍了修改Oracle字符集为UTF-8解决中文乱码问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

很多情况下,遇到数据库查询数据中文乱码,一般都是字符集的问题,下面记录一下oracle字符集的查看方法,并提供UTF-8字符集的修改方式。

1、查看数据库字符集

以下操作均在sqlplus或客户端中执行

数据库服务器字符集:

select * from nls_database_parameters;

其来源于props$,是表示数据库的字符集。

客户端字符集环境:

select * from nls_instance_parameters;

其来源于v$parameter,

表示客户端的字符集的设置,可能是参数文件,环境变量或者是注册表

会话字符集环境:

select * from nls_session_parameters;

其来源于v$nls_parameters,表示会话自己的设置,可能是会话的环境变量或者是alter session完成,如果会话没有特殊的设置,将与nls_instance_parameters一致。

重要提示:

客户端的字符集要求与服务器一致,才能正确显示数据库的非Ascii字符。

如果多个设置存在的时候:

alter session>环境变量>注册表>参数文件

2、修改oracle的字符集为UTF-8

① 在SQL PLUS 中,以DBA登录

conn sys/sys as sysdba;

② 执行转换语句:

SHUTDOWN IMMEDIATE; --先关掉数据库
STARTUP MOUNT EXCLUSIVE; 
ALTER SYSTEM ENABLE RESTRICTED SESSION;
ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0;
ALTER SYSTEM SET AQ_TM_PROCESSES=0;
ALTER DATABASE OPEN;
ALTER DATABASE NATIONAL CHARACTER SET AL32UTF8; --此处修改字符集关键语句
SHUTDOWN immediate; --修改完毕后重启数据库
STARTUP;

注意

如果没有大对象,在使用过程中进行语言转换没有什么影响,(切记设定的字符集必须是ORACLE支持,不然不能start)

上述过程可能会出现提示:

ORA-12717: Cannot ALTER DATABASE NATIONAL CHARACTER SET when NCLOB data exists

要解决这个问题有两种方法:

(1) 利用INTERNAL_USE关键字修改区域设置

SHUTDOWN IMMEDIATE; --同样需要关闭数据库
STARTUP MOUNT EXCLUSIVE; 
ALTER SYSTEM ENABLE RESTRICTED SESSION;
ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0;
ALTER SYSTEM SET AQ_TM_PROCESSES=0;
ALTER DATABASE OPEN;
ALTER DATABASE NATIONAL CHARACTER SET INTERNAL_USEAL32UTF8; --此处加上了INTENAL_USER
SHUTDOWN immediate;
startup;

(2) 利用re-create,但是re-create有点复杂,我也不会(逃) ③ 如果上面的方法执行有问题

可以在sqlplus中强制转换执行如下语句

update sys.props$ set value$= 'AL32UTF8' WHERE name = 'NLS_CHARACTERSET';
commit;

然后重新启动oracle或者重新启动Linux系统。

一定要再执行如下代码:

SHUTDOWN IMMEDIATE;
STARTUP MOUNT;
ALTER SYSTEM ENABLE RESTRICTED SESSION;
ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0;
ALTER SYSTEM SET AQ_TM_PROCESSES=0;
ALTER DATABASE OPEN;
COL VALUE NEW_VALUE CHARSET
SELECT VALUE FROM NLS_DATABASE_PARAMETERS WHERE PARAMETER='NLS_CHARACTERSET';
COL VALUE NEW_VALUE NCHARSET
SELECT VALUE FROM NLS_DATABASE_PARAMETERS WHERE PARAMETER='NLS_NCHAR_CHARACTERSET';
--INTERNAL_USE是没有写在文档中的参数,用以强制完成字符集一致化
ALTER DATABASE CHARACTER SET INTERNAL_USE &CHARSET;
ALTER DATABASE NATIONAL CHARACTER SET INTERNAL_USE &NCHARSET;
SHUTDOWN IMMEDIATE;
STARTUP;
-- 再次启动数据库一遍
SHUTDOWN IMMEDIATE;
STARTUP;

至此,EXP问题得到了解决。

注意:修改字符集只是修改了数据字典,并没有对数据进行字符集转换!

④ 如果语言环境不一致,语言环境同时更新掉:

update   sys.props$   set   value$= 'SIMPLIFIED CHINESE'   WHERE   name   =   'NLS_LANGUAGE';
update   sys.props$   set   value$= 'SIMPLIFIED CHINESE'   WHERE   name   =   'NLS_DATE_LANGUAGE';
update   sys.props$   set   value$= 'CHINA'   WHERE   name   =   'NLS_TERRITORY';
update   sys.props$   set   value$= 'CHINA'   WHERE   name   =   'NLS_ISO_CURRENCY';
update   sys.props$   set   value$= '?'   WHERE   name   =   'NLS_CURRENCY';
update   sys.props$   set   value$= '?'   WHERE   name   =   'NLS_DUAL_CURRENCY';
commit;

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Oracle查询优化日期运算实例详解

    Oracle查询优化日期运算实例详解

    这篇文章主要介绍了Oracle查询优化日期运算实例详解的相关资料,需要的朋友可以参考下
    2017-05-05
  • Oracle配置dblink访问PostgreSQL的操作方法

    Oracle配置dblink访问PostgreSQL的操作方法

    本文给大家介绍下Oracle配置dblink访问PostgreSQL的操作方法,通过dblink访问PostgreSQL的详细过程,对Oracle dblink访问PostgreSQL相关知识感兴趣的朋友一起看看吧
    2022-03-03
  • Oracle 手动创建数据库步骤详解

    Oracle 手动创建数据库步骤详解

    本文给大家介绍oracle手动创建数据库步骤,需要的朋友可以参考下
    2015-10-10
  • oracle 12c创建可插拔数据库(PDB)与用户详解

    oracle 12c创建可插拔数据库(PDB)与用户详解

    Oracle12c 中,增加了可插接数据库的概念,即PDB,允许一个数据库容器(CDB)承载多个可插拔数据库(PDB)。下面这篇文章主要给大家介绍了利用oracle 12c创建可插拔数据库(PDB)与用户的相关资料,文中介绍的很详细,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-02-02
  • ORACLE 自动提交问题

    ORACLE 自动提交问题

    通过PL/SQL DEVELOPER向数据库中的某个表中插入一定量的数据,通过select 语句可以看到已经插入到表中,然而诡异的是通过程序却无法查询到新插入的数据。
    2009-06-06
  • Oracle to_date()函数的用法介绍

    Oracle to_date()函数的用法介绍

    to_date()是Oracle数据库函数的代表函数之一,下文对Oracle to_date()函数的几种用法作了详细的介绍说明,需要的朋友可以参考下
    2014-08-08
  • Win7彻底卸载Oracle 11g图文步骤(靠谱)

    Win7彻底卸载Oracle 11g图文步骤(靠谱)

    网上资料结合自己的操作整理出的一套靠谱的彻底卸载Oracle 11g的图文步骤,非常不错,具有参考借鉴价值,需要的朋友参考下吧
    2017-03-03
  • oracle12c安装报错:PRVF-0002的解决方法

    oracle12c安装报错:PRVF-0002的解决方法

    本文为大家介绍下如何解决oracle12c安装报错:PRVF-0002,具体的排查思路如下,有类似情况的朋友可以参考下
    2013-09-09
  • oralce和db2兼容开发注意事项

    oralce和db2兼容开发注意事项

    这篇文章主要介绍了oralce和db2兼容开发注意事项的相关资料,这里整理了几个重要问题及如何解决,需要的朋友可以参考下
    2016-11-11
  • 解决ORA-01747:user.table.column,table.column或列说明无效

    解决ORA-01747:user.table.column,table.column或列说明无效

    这篇文章主要介绍了解决ORA-01747:user.table.column,table.column或列说明无效的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07

最新评论