英文xp操作系统,oracle出现的字符集问题

问题描述:pl/sql查询出的汉字都是“靠” -.- 插入记录可以输入中文,但提交后中文就变成乱码(系统其他地方都可以正常显示中文)

问题解决:浏览了很多贴子,查各种字符集

服务器字符集:

SQL> select * from nls_database_parameters;
 
PARAMETER                      VALUE
------------------------------ --------------------------------------------------------------------------------
NLS_LANGUAGE                   AMERICAN
NLS_TERRITORY                  AMERICA
NLS_CURRENCY                   $
NLS_ISO_CURRENCY               AMERICA
NLS_NUMERIC_CHARACTERS         .,
NLS_CHARACTERSET               ZHS16GBK
NLS_CALENDAR                   GREGORIAN
NLS_DATE_FORMAT                DD-MON-RR
NLS_DATE_LANGUAGE              AMERICAN
NLS_SORT                       BINARY
NLS_TIME_FORMAT                HH.MI.SSXFF AM
NLS_TIMESTAMP_FORMAT           DD-MON-RR HH.MI.SSXFF AM
NLS_TIME_TZ_FORMAT             HH.MI.SSXFF AM TZR
NLS_TIMESTAMP_TZ_FORMAT        DD-MON-RR HH.MI.SSXFF AM TZR
NLS_DUAL_CURRENCY              $
NLS_COMP                       BINARY
NLS_LENGTH_SEMANTICS           BYTE
NLS_NCHAR_CONV_EXCP            FALSE
NLS_NCHAR_CHARACTERSET         AL16UTF16
NLS_RDBMS_VERSION              9.2.0.1.0

 

客户端字符集:

SQL> select * from nls_instance_parameters;
 
PARAMETER                                                    VALUE
------------------------------------------------------------ --------------------------------------------------------------------------------
NLS_LANGUAGE                                                 AMERICAN
NLS_TERRITORY                                                AMERICA
NLS_SORT                                                    
NLS_DATE_LANGUAGE                                           
NLS_DATE_FORMAT                                             
NLS_CURRENCY                                                
NLS_NUMERIC_CHARACTERS                                      
NLS_ISO_CURRENCY                                            
NLS_CALENDAR                                                
NLS_TIME_FORMAT                                             
NLS_TIMESTAMP_FORMAT                                        
NLS_TIME_TZ_FORMAT                                          
NLS_TIMESTAMP_TZ_FORMAT                                     
NLS_DUAL_CURRENCY                                           
NLS_COMP                                                    
NLS_LENGTH_SEMANTICS                                         BYTE
NLS_NCHAR_CONV_EXCP                                          FALSE

 

SQL> select userenv('language') from dual;
 
USERENV('LANGUAGE')
----------------------------------------------------
AMERICAN_AMERICA.ZHS16GBK

服务器端与客户端的字符集都是ZHS16GBK,似乎没有问题

看到此贴:http://topic.csdn.net/t/20020830/17/983848.html

#4提到HKEY_LOCAL_MACHINE/SOFTWARE/ODBC/ORACLE/HOME0下的NLS_LANG,

HKEY_LOCAL_MACHINE/SOFTWARE/ODBC/ORACLE/HOME0没找到,但是有HKEY_LOCAL_MACHINE/SOFTWARE/ORACLE/HOME0,不管它。。可能是版本问题,点开来,果然有NLS_LANG。

嗯?AMERICAN_AMERICA.WE8MSWIN1252?不太对吧。。

回头看HKEY_LOCAL_MACHINE/SOFTWARE/ORACLE下的NLS_LANG,AMERICAN_AMERICA.ZHS16GBK!

应该是这里出了问题。

把WE8MSWIN1252改成ZHS16GBK,重启PL/SQL,果然问题解决了。

但是为什么任何查询都没有显示用了WE8MSWIN1252字符集呢?

再看看上面执行select * from nls_instance_parameters时,是没有NLS_CHARACTERSET这一行的,难道是默认成WE8MSWIN1252了?

猜测。。HKEY_LOCAL_MACHINE/SOFTWARE/ORACLE下的NLS_LANG是全局的,而HKEY_LOCAL_MACHINE/SOFTWARE/ORACLE/HOME0下的NLS_LANG是更低一级的,是对HOME0这个oracle实例设定的,将上面全局的设置覆盖了。

知其然,不知其所以然,还是很菜额。。

另外:另一台中文xp机子上,HKEY_LOCAL_MACHINE/SOFTWARE/ORACLE/NLS_LANG是NA。。。而HKEY_LOCAL_MACHINE/SOFTWARE/ORACLE/HOME0/NLS_LANG是SIMPLIFIED CHINESE_CHINA.ZHS16GBK,这台没有乱码问题。

 

参考:

1、http://topic.csdn.net/t/20020830/17/983848.html

2、http://falchion.javaeye.com/blog/586927

3、http://hi.baidu.com/linuxocp/blog/item/d662c228fc4aea335343c133.html

4、http://fanqiang.chinaunix.net/db/oracle/2001-04-16/1166.shtml

5、http://bbs.chinaunix.net/viewthread.php?tid=1299918

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值