PL/sql 启动时出现:NLS_LANG在客户端不能确定,字符集转变将造成不可预期的后果


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

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

我系统注册表有NLS_LANG键值。
看来得添加环境变量了(右击“我的电脑”,选择“属性”,再选择“高级”,接着点击“环境变量”,在“系统变量”一栏下“新建”),如下图:

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


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

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

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

关于nls_lang,涉及到了几个表:
v$nls_parameters,v$nls_valid_values,nls_database_parameters,nls_instance_parameters
v$nls_parameters就表示的是本地nls_lang设置了:

posted @ 2011-12-29 21:02  sekon  阅读(9252)  评论(1编辑  收藏  举报