深入探讨oracle字符编码问题,关于NLS_LANG

最近,好不容易用plsql developer连接上64位oracle了,不过有弹了一个错误:

NLS_LANG在客户端不能确定,字符集转变将造成不可预期的后果

lang

打开plsql developer帮助---支持信息--信息选项卡:

nlserror

看到ULS_LANG这行是空的。

确实,如果查询,表中的中文注释就是问号

怎么没加载呢?

regedit

我系统注册表有NLS_LANG键值。

看来得添加环境变量了,如下图:

nlslang

添加环境变量后,经过测试,加载成功。

此时,如果操作本地oracle数据库的话,提示肯定是中文的:

chs

windowsnlslang

如果你通过本地plsql developer操作远程数据库,提示是英文的话,就得看看远程系统nls_lang变量是什么的了:

servernlslang

远程系统nls_lang变量是AMERICAN_AMERICA.ZHS16GBK,所以提示是英文的了:

en

加载成功的结果可以在plsql developer中看到:

ulslang

关于nls_lang,涉及到了几个表:

v$nls_parameters,v$nls_valid_values,nls_database_parameters,nls_instance_parameters

v$nls_parameters就表示的是本地nls_lang设置了:

nlsparms

我主要以图说明了一下问题,一些其他的信息可以参考:

http://jelly.javaeye.com/blog/654300

http://kb.cnblogs.com/a/1368334/

http://www.itpub.net/viewthread.php?tid=735780&page=1#

转载于:https://www.cnblogs.com/william-lee/archive/2010/11/30/1892292.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值