zoukankan      html  css  js  c++  java
  • 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 
    export NLS_LANG=AMERICAN_AMERICA.WE8ISO8859P1

    Windows下为HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\HOMEx\NLS_LANG 如果有多个oracle产品,那么HOMEx可能就有多个,比如HOME0,HOME1...一般都有NLS_LANG这个注册项。

    在windows下也可以把NLS_LANG设置成环境变量,但这样做的比较少,一般还是在注册表里设置。

    DB中的NLS_LANG

    DB也有自己的NLS_LANG参数(值为 [NLS_LANGUAGE]_[NLS_TERRITORY].[NLS_CHARACTERSET])来标识数据库的语言,地域,字符集。可以通过以下的SQL来查得,

    SELECT * FROM v$nls_parameters; 
    
    OR
    
    SELECT USERENV ('language') FROM DUAL;

    客户端的NLS_LANG和DB的NLS_LANG

    DB的NLS_LANG和客户端环境变量中NLS_LANG尽可能的保持一致。

    客户端的NLS_LANG值为[NLS_LANGUAGE]_[NLS_TERRITORY].[NLS_CHARACTERSET].

    值为HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\HOMEx\NLS_LANG的值。

    那么为什么要保持一致呢?那是因为如果字符集不匹配,有可能在DB和Client间相互转换的过程中,出现字符转换错误的情况。

  • 相关阅读:
    【Spring】 AOP Base
    【Offer】[20] 【表示数值的字符串】
    【Offer】[19] 【字符串匹配】
    【设计模式】代理模式
    【LeetCode】[0002] 【两数之和】
    【Offer】[18-1] 【在O(1)时间内删除链表节点】
    【Offer】[18-2] 【删除链表中重复的节点】
    【Offer】[17] 【打印1到最大的n位数】
    【Offer】[16] 【数值的整数次方】
    python_内置函数
  • 原文地址:https://www.cnblogs.com/zhangsongshan/p/3133709.html
Copyright © 2011-2022 走看看