国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > 綜合 > 正文

[技術]淺談字符集問題

2024-07-21 02:40:26
字體:
來源:轉載
供稿:網友

淺談字符集問題
                                                       txfy
應論壇上的請求,先寫了這么個東西,還很不完善,慢慢補充,大家也多提意見!
一:首先介紹一個概念:
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&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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 广宗县| 湖南省| 建始县| 信阳市| 布拖县| 盐城市| 新河县| 永定县| 泸定县| 庆阳市| 昌黎县| 花莲县| 会宁县| 双流县| 治县。| 竹溪县| 浠水县| 鲁山县| 呼伦贝尔市| 吉安市| 浮山县| 水城县| 昌黎县| 浙江省| 武威市| 阜平县| 桃园县| 永年县| 汝南县| 大余县| 南乐县| 荃湾区| 中超| 元朗区| 绥德县| 临武县| 太白县| 漳州市| 剑河县| 保德县| 洪洞县|