oracle 字符乱码问题解决方案

今天在客户服务器上遇到了oracle中文乱码问题,第一个想到的是:要想避免oracle字符乱码的问题,须要注意oracle客户端的字符编码和服务端的字符编码保持一致。sql

因而操做以下:数据库

一、查看服务端字符集--结果:服务端是ZHS16GBK
SELECT * FROM NLS_DATABASE_PARAMETERS where parameter='NLS_CHARACTERSET';服务器

二、因而开始修改客户端字符集,方式以下:oracle

在运行里面,输入regedit进入注册表,HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\KEY_OraDb11g_home1\里面(最后一项与实例名、数据库版本有关系),找到NLS_LANG选项,双击它,你就能够看到相应的值,修改为AMERICAN_AMERICA.ZHS16GBK
三、查看客户端字符集--结果:客户端是AMERICAN_AMERICA.ZHS16GBK(注意:客户端保证.后面的部分和服务端一致便可)
SELECT USERENV('language') FROM DUAL;

app

可是作完以上操做若是仍是乱码,因而查看了一下环境变量,发现里面配置了一个NLS_LANG的变量,因而将其值设为AMERICAN_AMERICA.ZHS16GBK,此时直接经过命令行是没有乱码问题了,可是尝试经过plsql查询数据库,发现依旧乱码,这时想到一件事,oracle是64位的,当时经过plsql是不能直接链接的,须要装32位的客户端,而后别的同事写了一个plsqldev.bat文件放到了plsql的根目录下,才能链接oracle的,因而找到该文件,打开查看,文件内容以下:编码

@echo off 
set path=C:\app\Administrator\product\instantclient_10_2
set ORACLE_HOME=C:\app\Administrator\product\instantclient_10_2
set TNS_ADMIN=C:\app\Administrator\product\instantclient_10_2
set NLS_LANG=AMERICAN_AMERICA.AL32UTF8
start plsqldev.exe

 这时就明白了,该文件中指定的NLS_LANG是AL32UTF8编码,因而将其改为set NLS_LANG=AMERICAN_AMERICA.ZHS16GBK,此时plsql使用的32位的oracle客户端的编码就和服务端的编码保持一致了,都是ZHS16GBK,再尝试经过plsql查询数据库,此时乱码问题解决了。spa

相关文章
相关标签/搜索