Oracle 8i字符集亂碼問題析及其解決辦法
更新時(shí)間:2007年03月07日 00:00:00 作者:
正在看的ORACLE教程是:Oracle 8i字符集亂碼問題析及其解決辦法。一、問題描述
SQL Plus WorkSheet是一個(gè)窗口圖形界面的SQL語(yǔ)句編輯器,對(duì)于那些喜歡窗口界面而不喜歡字符界面的用戶,該工具相對(duì)SQL/PLUS受到了很大的歡迎。但從Oracle 8i以后,如果安裝Oracle 8i時(shí)選取的是別于英語(yǔ)的字符集,對(duì)于我們中國(guó),通常會(huì)選取簡(jiǎn)體中文字符集(ZHS16GBK),安裝成功后,運(yùn)行SQL Plus WorkSheet程序,會(huì)出現(xiàn)所有的中文顯示以及查詢結(jié)果均為亂碼的情況。
二、問題分析
最初出現(xiàn)該問題,首先懷疑就是安裝時(shí)字符集設(shè)置有問題,也就是說(shuō)沒有設(shè)置正確的簡(jiǎn)體中文字符集。首先檢查數(shù)據(jù)庫(kù)字符集,在SQL/PLUS中,運(yùn)行下面的SQL語(yǔ)句,檢查所連接數(shù)據(jù)庫(kù)的字符集:
查詢結(jié)果發(fā)現(xiàn)數(shù)據(jù)庫(kù)安裝時(shí)所選字符集為簡(jiǎn)體中文ZHS16GBK,說(shuō)明安裝時(shí)字符集設(shè)置完全正確。第二步開始懷疑是用戶客戶端字符集問題,檢查客戶端注冊(cè)表,打開注冊(cè)表編輯程序(RegEdit),在HKEY_LOCAL_MACHINE/SOFTWARE/ORACLE/NLS_LANG,發(fā)現(xiàn)Oracle客戶端字符集為AMERICAN_AMERICA.ZHS16GBK,設(shè)置也完全正確,可以排除是客戶端字符集設(shè)置錯(cuò)誤的問題。同時(shí)還有一個(gè)現(xiàn)象就是在同一個(gè)客戶端機(jī)器上SQL/PLUS中的查詢字符集顯示完全正常,這也說(shuō)明不是字符集設(shè)置問題,而是系統(tǒng)程序SQL/Plus Worksheet的問題。
在Oracle 8i以前的版本中,從來(lái)沒有出現(xiàn)過這樣的情況,這應(yīng)該和Oracle版本有關(guān),我們知道Oracle 8i和它前面的版本一個(gè)顯著的區(qū)別就是大部分的Oracle系統(tǒng)程序,現(xiàn)在均采用Java驅(qū)動(dòng),其實(shí)這也就是產(chǎn)生字符集亂碼問題的根本所在。非Java驅(qū)動(dòng)的程序,如SQL*Plus,有一個(gè)系統(tǒng)參數(shù)NLS_LANG,該參數(shù)在UNIX系統(tǒng)中設(shè)置在環(huán)境變量中,在Windows操作系統(tǒng)中設(shè)置在注冊(cè)表中,這個(gè)參數(shù)決定了客戶端應(yīng)用程序的字符集。而對(duì)于基于Java應(yīng)用的程序,如現(xiàn)在遇到的SQL*PLus Worksheet,NLS_LANG參數(shù)對(duì)這類程序是不起任何作用的。
三、解決方案
找到了問題產(chǎn)生的原因后,下面來(lái)討論如何解決該問題。對(duì)于Oracle Enterprise Manager中的所有工具,有一個(gè)配置文件名為dbappscfg.properties,修改該文件即可解決上述問題。這個(gè)文件的位置在$ORACLE_HOME\sysman\config目錄下,用任何的文本編輯器打開該文件,在這個(gè)文件里面,找到這樣一項(xiàng),
去掉注釋符#,同時(shí)將其修改為SQLPLUS_NLS_LANG=AMERICAN_AMERICA.ZHS16GBK。
對(duì)于Windows操作系統(tǒng),還需要修改一項(xiàng),在文件中找到# SQLPLUS_SYSTEMROOT=c:\\WINNT40,去掉注釋符,將其修改為你所在機(jī)器的操作系統(tǒng)主目錄。如操作系統(tǒng)的主目錄在D盤的Winnt下,則將其修改為 SQLPLUS_SYSTEMROOT=d:\\WINNT。
對(duì)于后面一項(xiàng)的修改只對(duì)Windows操作系統(tǒng)進(jìn)行,對(duì)UNIX操作系統(tǒng)則不需要。如果在Windows操作系統(tǒng)中不修改該項(xiàng),在Oracle Enterprise Manager中,連接系統(tǒng)時(shí),會(huì)提示如下的錯(cuò)誤:
或者
修改完成后,保存文件,退出編輯。重新連接SQL PLUS Worksheet,字符集亂碼問題得到解決,顯示正確的簡(jiǎn)體中文字符集。
SQL Plus WorkSheet是一個(gè)窗口圖形界面的SQL語(yǔ)句編輯器,對(duì)于那些喜歡窗口界面而不喜歡字符界面的用戶,該工具相對(duì)SQL/PLUS受到了很大的歡迎。但從Oracle 8i以后,如果安裝Oracle 8i時(shí)選取的是別于英語(yǔ)的字符集,對(duì)于我們中國(guó),通常會(huì)選取簡(jiǎn)體中文字符集(ZHS16GBK),安裝成功后,運(yùn)行SQL Plus WorkSheet程序,會(huì)出現(xiàn)所有的中文顯示以及查詢結(jié)果均為亂碼的情況。
二、問題分析
最初出現(xiàn)該問題,首先懷疑就是安裝時(shí)字符集設(shè)置有問題,也就是說(shuō)沒有設(shè)置正確的簡(jiǎn)體中文字符集。首先檢查數(shù)據(jù)庫(kù)字符集,在SQL/PLUS中,運(yùn)行下面的SQL語(yǔ)句,檢查所連接數(shù)據(jù)庫(kù)的字符集:
查詢結(jié)果發(fā)現(xiàn)數(shù)據(jù)庫(kù)安裝時(shí)所選字符集為簡(jiǎn)體中文ZHS16GBK,說(shuō)明安裝時(shí)字符集設(shè)置完全正確。第二步開始懷疑是用戶客戶端字符集問題,檢查客戶端注冊(cè)表,打開注冊(cè)表編輯程序(RegEdit),在HKEY_LOCAL_MACHINE/SOFTWARE/ORACLE/NLS_LANG,發(fā)現(xiàn)Oracle客戶端字符集為AMERICAN_AMERICA.ZHS16GBK,設(shè)置也完全正確,可以排除是客戶端字符集設(shè)置錯(cuò)誤的問題。同時(shí)還有一個(gè)現(xiàn)象就是在同一個(gè)客戶端機(jī)器上SQL/PLUS中的查詢字符集顯示完全正常,這也說(shuō)明不是字符集設(shè)置問題,而是系統(tǒng)程序SQL/Plus Worksheet的問題。
在Oracle 8i以前的版本中,從來(lái)沒有出現(xiàn)過這樣的情況,這應(yīng)該和Oracle版本有關(guān),我們知道Oracle 8i和它前面的版本一個(gè)顯著的區(qū)別就是大部分的Oracle系統(tǒng)程序,現(xiàn)在均采用Java驅(qū)動(dòng),其實(shí)這也就是產(chǎn)生字符集亂碼問題的根本所在。非Java驅(qū)動(dòng)的程序,如SQL*Plus,有一個(gè)系統(tǒng)參數(shù)NLS_LANG,該參數(shù)在UNIX系統(tǒng)中設(shè)置在環(huán)境變量中,在Windows操作系統(tǒng)中設(shè)置在注冊(cè)表中,這個(gè)參數(shù)決定了客戶端應(yīng)用程序的字符集。而對(duì)于基于Java應(yīng)用的程序,如現(xiàn)在遇到的SQL*PLus Worksheet,NLS_LANG參數(shù)對(duì)這類程序是不起任何作用的。
三、解決方案
找到了問題產(chǎn)生的原因后,下面來(lái)討論如何解決該問題。對(duì)于Oracle Enterprise Manager中的所有工具,有一個(gè)配置文件名為dbappscfg.properties,修改該文件即可解決上述問題。這個(gè)文件的位置在$ORACLE_HOME\sysman\config目錄下,用任何的文本編輯器打開該文件,在這個(gè)文件里面,找到這樣一項(xiàng),
去掉注釋符#,同時(shí)將其修改為SQLPLUS_NLS_LANG=AMERICAN_AMERICA.ZHS16GBK。
對(duì)于Windows操作系統(tǒng),還需要修改一項(xiàng),在文件中找到# SQLPLUS_SYSTEMROOT=c:\\WINNT40,去掉注釋符,將其修改為你所在機(jī)器的操作系統(tǒng)主目錄。如操作系統(tǒng)的主目錄在D盤的Winnt下,則將其修改為 SQLPLUS_SYSTEMROOT=d:\\WINNT。
對(duì)于后面一項(xiàng)的修改只對(duì)Windows操作系統(tǒng)進(jìn)行,對(duì)UNIX操作系統(tǒng)則不需要。如果在Windows操作系統(tǒng)中不修改該項(xiàng),在Oracle Enterprise Manager中,連接系統(tǒng)時(shí),會(huì)提示如下的錯(cuò)誤:
或者
修改完成后,保存文件,退出編輯。重新連接SQL PLUS Worksheet,字符集亂碼問題得到解決,顯示正確的簡(jiǎn)體中文字符集。
相關(guān)文章
oracle中add_months()函數(shù)及用法總結(jié)
這篇文章主要介紹了oracle中add_months()函數(shù)及用法總結(jié),非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-08-08oracle刪除主鍵查看主鍵約束及創(chuàng)建聯(lián)合主鍵
本節(jié)文章主要介紹了oracle刪除主鍵查看主鍵約束及創(chuàng)建聯(lián)合主鍵,示例代碼如下,需要的朋友可以參考下2014-07-07ip修改后orcale服務(wù)無(wú)法啟動(dòng)問題解決
今天配置虛擬機(jī)中設(shè)計(jì)了下ip,使虛擬機(jī)和主機(jī)處在同一網(wǎng)段,然后使用webservice就成功了就來(lái)了,oracle連接不上了,接下來(lái)講提供詳細(xì)的解決方法2012-11-11Oracle刪除字段中的空格、回車及指定字符的實(shí)例代碼
本文給大家分享Oracle刪除字段中的空格、回車及指定字符的實(shí)例代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的的朋友參考下2017-03-03Oracle停止數(shù)據(jù)泵導(dǎo)入數(shù)據(jù)的方法詳解
Oracle數(shù)據(jù)庫(kù)在使用的過程中常常會(huì)遇到這樣或那樣的問題,而這些問題常常又使我們感到很困惑,下面這篇文章主要給大家介紹了關(guān)于Oracle停止數(shù)據(jù)泵導(dǎo)入數(shù)據(jù)的相關(guān)資料,需要的朋友可以參考下2022-06-06關(guān)于sql腳本導(dǎo)入Oracle時(shí)重復(fù)生成check約束的問題解決
這篇文章主要給大家介紹了關(guān)于sql腳本導(dǎo)入Oracle時(shí)重復(fù)生成check約束的問題解決方法,文中給出了詳細(xì)的檢查步驟,對(duì)大家理解和解決這個(gè)問題具有很好的幫助,需要的朋友們下面來(lái)一起看看吧。2017-05-05