ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

解决ORA-12705无法访问NLS问题

2019-08-02 17:56:31  阅读:188  来源: 互联网

标签:LANG NLS windows 无法访问 nls 12705 设置 环境变量


通过putty sql_plus 连接数据库报错:
ORA-12705:Cannot access NLS data files or invalid environment specified

此问题主要是putty登录后的系统linux/windows当前环境变量NLS_LANG设置和数据库NLS_LANG参数变量不一致导致.

NLS_LANG参数由以下部分组成:
NLS_LANG=[Language]_[Territory].[Clients Characterset]

NLS_Language 指定:

  • Oracle(错误)信息的语言
  • 日和月份的名称
    注意:NLS_LANGUAGE与插入和查询的数据的语言无关。

NLS_Territory 指定:

  • 货币和数字格式
  • 计算星期和天数的范围和惯例

客户端字符集(CLIENTS CHARACTERSET):

  • 定义Oracle客户端,客户应用使用的编码
  • 或者它要符合您Microsoft Windows代码页 (GUI工具的ACP, 命令提示符的CHCP 值)
  • 或者为Unicode WIN32应用设置为UTF8/AL32UTF8。

1.首先查询数据库的语言字符集环境变量;

 SELECT 
 (SELECT VALUE  from nls_database_parameters
 WHERE parameter='NLS_LANGUAGE')
 ||'_'||
  (SELECT VALUE  from nls_database_parameters
 WHERE parameter='NLS_TERRITORY')
 ||'.'||
   (SELECT VALUE  from nls_database_parameters
 WHERE parameter='NLS_CHARACTERSET') NLS_LANG
 FROM dual;

注意:

select userenv('language') from dual;
--或
select * from v$nls_parameters;

如上查询只能查询出数据库当前session的语言字符集,

2.在putty linux 中查询当前的环境变量NLS_LANG是否和数据库语言字符集保持一致.

env | grep NLS_LANG

3.不一致则使用export 命令设置linux环境变量NLS_LANG的值
linux例如:export NLS_LANG=AMERICAN_AMERICA.AL32UTF8

如果要永久更新此变量需要在.bash_profile文件中设置或添加的NLS_LANG
例如:vi ~/.bash_profile

注:远程机器如果为windows;
windows设置NLS_LANG有三种方式
1.cmd命令如下:
set nls_lang=AMERICAN_AMERICA.AL32UTF8

2..注册表设置(永久生效)
默认情况下,windows上的Oracle安装使用注册表来定义这个设置。
版本 10g 及以上:
HKEY_LOCALMACHINE\SOFTWARE\ORACLE\KEY<oracle_home_name>
这里您会看到一个条目名为NLS_LANG

在64位windows平台上安装32位软件,会使用32位兼容性路径
HKEY_LOCALMACHINE\SOFTWARE\Wow6432Node\ORACLE\KEY<oracle_home_name>

3..操作系统环境变量
尽管注册表是Microsoft Windows设置的主要存储位置,它不是唯一可以设置参数的地方。
虽然不推荐,但您可以设置NLS_LANG为系统属性中的系统或者用户变量。这个设置会被所有Oracle home使用。
设置位置: '我的电脑' -> '属性' > '高级' -> '环境变量'

标签:LANG,NLS,windows,无法访问,nls,12705,设置,环境变量
来源: https://blog.51cto.com/aaron521/2426023

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有