佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > Oracle 8i字符集亂碼問題析及其解決辦法

Oracle 8i字符集亂碼問題析及其解決辦法

熱門標簽:AI電銷 Linux服務器 網(wǎng)站排名優(yōu)化 鐵路電話系統(tǒng) 百度競價排名 服務外包 地方門戶網(wǎng)站 呼叫中心市場需求
正在看的ORACLE教程是:Oracle 8i字符集亂碼問題析及其解決辦法。一、問題描述

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

  二、問題分析

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


  查詢結(jié)果發(fā)現(xiàn)數(shù)據(jù)庫安裝時所選字符集為簡體中文ZHS16GBK,說明安裝時字符集設(shè)置完全正確。第二步開始懷疑是用戶客戶端字符集問題,檢查客戶端注冊表,打開注冊表編輯程序(RegEdit),在HKEY_LOCAL_MACHINE/SOFTWARE/ORACLE/NLS_LANG,發(fā)現(xiàn)Oracle客戶端字符集為AMERICAN_AMERICA.ZHS16GBK,設(shè)置也完全正確,可以排除是客戶端字符集設(shè)置錯誤的問題。同時還有一個現(xiàn)象就是在同一個客戶端機器上SQL/PLUS中的查詢字符集顯示完全正常,這也說明不是字符集設(shè)置問題,而是系統(tǒng)程序SQL/Plus Worksheet的問題。

  在Oracle 8i以前的版本中,從來沒有出現(xiàn)過這樣的情況,這應該和Oracle版本有關(guān),我們知道Oracle 8i和它前面的版本一個顯著的區(qū)別就是大部分的Oracle系統(tǒng)程序,現(xiàn)在均采用Java驅(qū)動,其實這也就是產(chǎn)生字符集亂碼問題的根本所在。非Java驅(qū)動的程序,如SQL*Plus,有一個系統(tǒng)參數(shù)NLS_LANG,該參數(shù)在UNIX系統(tǒng)中設(shè)置在環(huán)境變量中,在Windows操作系統(tǒng)中設(shè)置在注冊表中,這個參數(shù)決定了客戶端應用程序的字符集。而對于基于Java應用的程序,如現(xiàn)在遇到的SQL*PLus Worksheet,NLS_LANG參數(shù)對這類程序是不起任何作用的。

  三、解決方案

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


  去掉注釋符#,同時將其修改為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)時,會提示如下的錯誤:


  或者 


  修改完成后,保存文件,退出編輯。重新連接SQL PLUS Worksheet,字符集亂碼問題得到解決,顯示正確的簡體中文字符集。 

您可能感興趣的文章:
  • 使用工具 plsqldev將Excel導入Oracle數(shù)據(jù)庫
  • oracle(plsql)生成流水號
  • plsql連接oracle數(shù)據(jù)庫報ora 12154錯誤解決方法
  • oracle客戶端PLSQL連接失敗解決方法
  • oracle中文亂碼的解決方法
  • oracle中文亂碼解決的辦法
  • oracle em 按鈕亂碼解決辦法及em網(wǎng)頁變成英文
  • oracle安裝出現(xiàn)亂碼等相關(guān)問題
  • Oracle客戶端與plsql查詢數(shù)據(jù)亂碼修改成中文的快速解決方法

標簽:崇左 衡水 湘潭 蘭州 湖南 銅川 仙桃 黃山

巨人網(wǎng)絡(luò)通訊聲明:本文標題《Oracle 8i字符集亂碼問題析及其解決辦法》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    拜泉县| 阿合奇县| 西畴县| 晋江市| 平果县| 道孚县| 沾化县| 东兰县| 海门市| 平罗县| 皮山县| 老河口市| 凤城市| 桂阳县| 新民市| 富民县| 定远县| 博兴县| 临沧市| 环江| 乌海市| 双柏县| 石楼县| 桦川县| 扎赉特旗| 彭泽县| 缙云县| 酉阳| 威信县| 陇南市| 吉水县| 大庆市| 赫章县| 凯里市| 农安县| 三江| 南澳县| 商南县| 靖州| 固阳县| 乌审旗|