通过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 指定:
NLS_Territory 指定:
客户端字符集(CLIENTS CHARACTERSET):
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使用。
设置位置: '我的电脑' -> '属性' > '高级' -> '环境变量'
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。