NLS_LANG格式:
NLS_LANG=LANGUAGE_TERRITORY.Client CHARACTERSET
1、NLS_LANG 參數組成
NLS_LANG參數由以下部分組成:
NLS_LANG=<Language>_<Territory>.<Clients Characterset>
NLS_LANG各部分含義如下:
LANGUAGE指定:
Oracle訊息使用的語言
日期中月份和日顯示
TERRITORY指定
貨幣和數字格式
地區和計算星期及日期的習慣
CHARACTERSET:
控制用戶端應用程式使用的字元集
在Oracle NLS_LANG設定中通常設定或者等於用戶端(如Windows)字碼頁
或者對於unicode應用設定為UTF8
查看當前oracle使用的CHARACHERSET:
select * from v$nls_parameters where parameter='NLS_CHARACTERSET';
查看instance字元集Language與Territory:
select * from nls_instance_parameters;
NLS_LANGUAGE
NLS_TERRITORY
查看這兩項
2、查看NLS_LANG設定:
env|grep NLS_LANG
一:介紹一個概念:
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檔案頭的原理。
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