自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Oracle 8i中字符集亂碼問題詳細解析

數(shù)據(jù)庫 Oracle
我們今天主要討論的是Oracle 8i中相關字符集亂碼的問題的詳細分析以及其具體的解決辦法,以下就是文章的具體內(nèi)容的描述。

以下的文章主要是介紹Oracle 8i中相關的字符集亂碼問題的分析以及其具體的解決辦法。以下的文章主要是對其相關問題的具體描述,以及相關的問題分析,以下就是相關內(nèi)容介紹。希望會給你帶來一些幫助在此方面。

一、問題描述

SQL Plus WorkSheet作為窗口圖形界面的SQL語句的編輯器,對于那些喜歡窗口界面而不喜歡字符界面的用戶,該工具相對SQL/PLUS受到了很大的歡迎。但從Oracle 8i以后,如果安裝Oracle 8i時選取的是別于英語的字符集,對于我們中國,通常會選取簡體中文字符集(ZHS16GBK),安裝成功后,運行SQL Plus WorkSheet程序,會出現(xiàn)所有的中文顯示以及查詢結果均為亂碼的情況。

二、問題分析

最初出現(xiàn)該問題,首先懷疑就是安裝時字符集設置有問題,也就是說沒有設置正確的簡體中文字符集。首先檢查數(shù)據(jù)庫字符集,在SQL/PLUS中,運行下面的SQL語句,檢查所連接數(shù)據(jù)庫的字符集:

  1. SQL> select userenv('language') from dual;  
  2. USERENV('LANGUAGE')  
  3. SIMPLIFIED CHINESE_CHINA.ZHS16GBK   

 

查詢結果發(fā)現(xiàn)數(shù)據(jù)庫安裝時所選字符集為簡體中文ZHS16GBK,說明安裝時字符集設置完全正確。第二步開始懷疑是用戶客戶端字符集問題,檢查客戶端注冊表,打開注冊表編輯程序(RegEdit),在HKEY_LOCAL_MACHINE/SOFTWARE/ORACLE/NLS_LANG,發(fā)現(xiàn)Oracle客戶端字符集為AMERICAN_AMERICA.ZHS16GBK,設置也完全正確,可以排除是客戶端字符集設置錯誤的問題。

同時還有一個現(xiàn)象就是在同一個客戶端機器上SQL/PLUS中的查詢字符集顯示完全正常,這也說明不是字符集設置問題,而是系統(tǒng)程序SQL/Plus Worksheet的問題。

在Oracle 8i以前的版本中,從來沒有出現(xiàn)過這樣的情況,這應該和Oracle版本有關,我們知道Oracle 8i和它前面的版本一個顯著的區(qū)別就是大部分的Oracle系統(tǒng)程序,現(xiàn)在均采用Java驅動,其實這也就是產(chǎn)生字符集亂碼問題的根本所在。

非Java驅動的程序,如SQL*Plus,有一個系統(tǒng)參數(shù)NLS_LANG,該參數(shù)在UNIX系統(tǒng)中設置在環(huán)境變量中,在Windows操作系統(tǒng)中設置在注冊表中,這個參數(shù)決定了客戶端應用程序的字符集。而對于基于Java應用的程序,如現(xiàn)在遇到的SQL*PLus Worksheet,NLS_LANG參數(shù)對這類程序是不起任何作用的。

三、解決方案

找到了問題產(chǎn)生的原因后,下面來討論如何解決該問題。對于Oracle Enterprise Manager中的所有工具,有一個配置文件名為dbappscfg.properties,修改該文件即可解決上述問題。這個文件的位置在$ORACLE_HOME\sysman\config目錄下,用任何的文本編輯器打開該文件,在這個文件里面,找到這樣一項,

 

  1. SQLPLUS_NLS_LANG=AMERICAN_AMERICA.WE8ISO8859P1  

去掉注釋符#,同時將其修改為SQLPLUS_NLS_LANG=AMERICAN_AMERICA.ZHS16GBK。

對于Windows操作系統(tǒng),還需要修改一項,在文件中找到# SQLPLUS_SYSTEMROOT=c:\\WINNT40,去掉注釋符,將其修改為你所在機器的操作系統(tǒng)主目錄。如操作系統(tǒng)的主目錄在D盤的Winnt下,則將其修改為 SQLPLUS_SYSTEMROOT=d:\\WINNT。

對于后面一項的修改只對Windows操作系統(tǒng)進行,對UNIX操作系統(tǒng)則不需要。如果在Windows操作系統(tǒng)中不修改該項,在Oracle Enterprise Manager中,連接系統(tǒng)時,會提示如下的錯誤:

 

  1. ORA-12560 TNS:protocol adapter error  

或者

 

  1. ORA-12545 Connect failed because target host or object does not exist  

修改完成后,保存文件,退出編輯。重新連接SQL PLUS Worksheet,字符集亂碼問題得到解決,顯示正確的簡體中文字符集。以上的相關內(nèi)容就是對Oracle 8i中字符集亂碼問題析及其解決辦法的介紹,望你能有所收獲。

文章出自: http://www.programbbs.com/doc/class10-3.htm

【編輯推薦】

  1. Oracle的實體-Oracle關系模型
  2. Oracle強制訪問中的系統(tǒng)沖突
  3. Oracle DRCP與PHP的不同之處
  4. Oracle In-Memory Undo特性淺談
  5. 修改Oracle***連接數(shù)的步驟有哪些
責任編輯:佚名 來源: programbbs
相關推薦

2010-04-22 09:08:30

Oracle 8i

2010-05-05 17:29:40

Oracle 8i

2010-03-30 14:53:42

Oracle 8i

2009-07-01 00:23:40

MySQL字符集亂碼

2011-04-11 11:05:12

Oracle字符集

2010-04-30 10:16:22

Oracle字符集

2011-05-20 13:24:39

oracle字符集

2009-11-20 16:52:35

Oracle字符集

2011-04-11 10:59:33

Oracle字符集

2009-01-06 09:14:08

8i9ioracle

2010-04-28 17:29:07

Oracle字符集

2010-05-06 18:01:07

Oracle Expr

2010-04-13 13:41:47

Oracle 字符集

2010-04-13 12:56:16

Oracle字符集

2010-04-13 13:11:34

Oracle漢字顯示

2011-05-16 13:15:55

MySQL存儲字符集

2009-07-29 13:42:04

Oracle中文顯示

2010-05-06 14:40:59

Oracle字符集

2010-04-13 11:35:26

Oracle字符集

2010-04-13 12:32:38

Oracle字符集
點贊
收藏

51CTO技術棧公眾號