Welcome 微信登录

首页 / 数据库 / MySQL / Oracle环境变量NLS_LANG

什么是NLS_LANG

NLS_LANG是一个环境变量,用于定义语言,地域以及字符集属性。对于非英语的字符集,NLS_LANG的设置就非常重要。
NLS:‘National Language Support (NLS)’ 当我们设定一种nls的时候实际上我们是为Oracle在存放数据时指定了他的语种所特有的一些表达形式,比如我们选择chinese,那么它的中文字符如何存放,按什么规则排序,货币如何表示,日期格式也就被设定了。

NLS_LANG格式

NLS_LANG = language_territory.charset常见的值可以参见Oracle Database Client Globalization Support

NLS_LANG的设置

Unix下NLS_LANG是一个环境变量,Windows下NLS_LANG一般是在注册表里设置的。Unix下的设置
  1. export NLS_LANG=AMERICAN_AMERICA.WE8ISO8859P1  
Windows下为HKEY_LOCAL_MACHINESOFTWAREORACLEHOMExNLS_LANG
如果有多个oracle产品,那么HOMEx可能就有多个,比如HOME0,HOME1...一般都有NLS_LANG这个注册项。在Windows下也可以把NLS_LANG设置成环境变量,但这样做的比较少,一般还是在注册表里设置。

DB中的NLS_LANG

DB也有自己的NLS_LANG参数,来标识数据库的语言,地域,字符集。可以通过以下的SQL来查得,
  1. SELECT * FROM v$nls_parameters;   
  2.   
  3. OR  
  4.   
  5. SELECT USERENV ("language") FROM DUAL;  

客户端的NLS_LANG和DB的NLS_LANG

DB的NLS_LANG和客户端环境变量中NLS_LANG尽可能的保持一致。Setting the NLS_LANG Environment Variable for Oracle Databases 提供了如何保持一致的方法。那么为什么要保持一致呢?那是因为如果字符集不匹配,有可能在DB和Client间相互转换的过程中,出现字符转换错误的情况。比如Oracle nls_lang tips中举的例子。

参考:NLS_LANG FAQ
Oracle Database Client Globalization Support
Setting the NLS_LANG Environment Variable for Oracle Databases关于Oracle DB中SQL Script的注释(REM,--,/* */)11gR2 新特性:Oracle Cluster Health Monitor(CHM)简介相关资讯      Oracle环境变量 
  • Oracle环境变量设置脚本  (今 13:03)
  • 环境变量 ORACLE_SID 简述  (11/26/2014 20:07:31)
  • Linux下Oracle设置环境变量  (02/08/2013 14:30:34)
  • Linux下Oracle环境变量无效问题解  (01月14日)
  • Linux下安装Oracle的常用设置参数  (01/24/2014 09:25:32)
本文评论 查看全部评论 (0)
表情: 姓名: 字数