首页 > 其他 > 详细

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

时间:2020-12-22 22:05:51      阅读:54      评论:0      收藏:0      [点我收藏+]

一、问题出现情况

技术分享图片

二、解决步骤

  1. 打开plsql developer帮助---支持信息--信息选项卡:
    技术分享图片

     

     看到NLS_LANG这行是空的。确实,如果查询,表中的中文注释就是问号怎么没加载呢?

  2. 检查注册表
    技术分享图片

     

     系统注册表有NLS_LANG键值。

  3. 添加环境变量

    添加环境变量了(右击“我的电脑”,选择“属性”,再选择“高级”,接着点击“环境变量”,在“系统变量”一栏下“新建”),如下图:

技术分享图片

 

 

三、测试验证

  添加环境变量后,经过测试,加载成功。此时,如果操作本地oracle数据库的话,提示肯定是中文的:
技术分享图片

 

 技术分享图片

 

 

四、英文提示

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

 

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

技术分享图片

 

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

技术分享图片

 

 

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

select * from v$nls_parameters;

select * from v$nls_valid_values;

select * from nls_database_parameters;

select * from nls_instance_parameters;

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

 技术分享图片

 

 

 

 

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

原文:https://www.cnblogs.com/liuqq1015/p/14175290.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!