天天看點

Oracle的NLS設定

轉載自:http://www.linuxidc.com/Linux/2011-02/32686.htm

一:介紹一個概念:

  NLS  ‘National Language Support (NLS)’ 從概念我們看出這個參數實際上定義了資料庫的存放資料的語言環境,當我們設定一種nls的時候實際上我們是為oracle在存放資料時指定了他的語種所特 有的一些表達形式,比如我們選擇chinese,那麼它的中文字元如何存放,按什麼規則排序,貨币如何表示,日期格式也就被設定了。

  

  二:如何查詢我們的資料庫中到底使用的是什麼字元集

  SQL> select * from V$NLS_PARAMETERS;

  NLS_LANGUAGE                     SIMPLIFIED CHINESE

  NLS_TERRITORY                          CHINA

  NLS_CURRENCY                           RMB

  NLS_ISO_CURRENCY                         CHINA

  NLS_NUMERIC_CHARACTERS                      .,

  NLS_CALENDAR                         GREGORIAN

  NLS_DATE_FORMAT                       DD-MON-RR

  NLS_DATE_LANGUAGE                  SIMPLIFIED CHINESE

  NLS_CHARACTERSET                       ZHS16GBK

  NLS_SORT                             BINARY

  NLS_TIME_FORMAT                      HH.MI.SSXFF AM

  NLS_TIMESTAMP_FORMAT             DD-MON-RR HH.MI.SSXFF AM

  NLS_TIME_TZ_FORMAT                  HH.MI.SSXFF AMTZR

  NLS_TIMESTAMP_TZ_FORMAT         DD-MON-RR HH.MI.SSXFF AM TZR

  NLS_DUAL_CURRENCY                        RMB

  NLS_NCHAR_CHARACTERSET                  AL16UTF16

  NLS_COMP                             BINARY

  NLS_LENGTH_SEMANTICS                       BYTE

  NLS_NCHAR_CONV_EXCP                       FALSE

  其中nls_language表示了中文顯示方式,nls_characterset是字元集設定,另外date,time等為日期時間的格式,currency是貨币格式。

  

  三:存在問題及解決方法

  我們在使用字元集過程中主要存在兩種問題。

  

  一是我們在查詢時顯示中文部分顯示亂字元。

  這一般是由于伺服器端的字元集設定與用戶端的字元集設定不同造成的。隻要将兩者修改一緻就可以解決問題。

  在windows裡需要到系統資料庫裡local machine-software-oracle-home0裡更改nls_lang,unix下需要在.profile或這.bash_profile(根據你用的shell)裡更改nls_lang.

  二是我們在導入資料時提示字元集不比對問題。(有些可以相容的不用管)

  解決方法目前我看到3種

   1:)exp/imp與sql*plus一樣是用戶端産品,是以他的字元集是由服務端的nls_lang所設定的。用exp導出備份的export file時,字元集的設定也被存放在export file裡。這就是有些人在imp發生字元無法轉換時更改export file檔案頭的原理。(相關内容可以看看http://chinaunix.net/forum/viewtopic.php?t=22352& amp;highlight=字元)

  2:) <=8.1

  在imp之前執行SQL > create database character set US7ASCII 

  * create database character set US7ASCII 

  ERROR at line 1: 

  ORA-01031: insufficient privileges 

   ---- 你會發現語句執行過程中,出現上述錯誤提示資訊,此時不用理會,實際上ORACLE資料庫的字元集已被強行修改為US7ASCII,接着用imp指令裝載 資料。等資料裝載完成以後,shutdown 資料庫,再startup 資料庫,用合法使用者登入ORACLE資料庫,在sql>指令提示符下,運作select * from V$NLS_PARAMETERS,可以看到ORACLE資料庫字元集已複原,這時再檢視有漢字字元資料的表時,漢字已能被正确顯示。 

  3:)用資料管道導入資料

  這種方法我早期用過pb6的資料管道,将資料管道連接配接至需要導入導出的兩個資料庫進行資料傳輸,傳輸後中文顯示沒有問題。

  4:)更該資料字典props$  >8.1

  1. )Use SQL*Plus connect to database as user SYS 

  2. )Issue this below command 

  SQL> UPDATE PROPS$ SET VALUE$='xxx' WHERE NAME='NLS_CHARACTERSET'; 

  3.) Shutdown database and restart it 

  最後添加一個關于字元集可以自動轉換方面的(在imp時):

  Warning You can't change character set of current database that have number of bits greater than the new one. For example, 

  我了解就是7-8 can,8-8ican,8-8cannot,8-7cannot

  US7ASCII -> WE8ISO8859P1 => Can 

  TH8TISASCII -> US7ASCII => Cannot 

  WE8ISO8859P1 -> TH8TISASCII => Cannot 

  TH8TISASCII -> WE8ISO8859P1 => Can 

  US7ASCII -> TH8TISASCII => Can