如何更改Oracle字符集國內(nèi)最常用的Oracle字符集ZHS16GBK(GBK 16-bit Simplified Chinese)能夠支持繁體中文,并且按照2個字符長度存儲一個漢字。UTF8字符集是多字節(jié)存儲,1個漢字(簡體、繁體)有時采用3個字符長度存儲。Oracle支持字符集的更改,但是UTF8是Oracle中最大的字符集,也就是說UTF8是ZHS16GBK的嚴格超集。對于子集到超集的轉換,Oracle是允許的,但是對于超集到子集的轉換是不允許的。一般對于超集到子集的轉換,建議是通過dbca刪除原來的數(shù)據(jù)庫,重新再建庫,選擇正確的字符集,然后導入備份。我的方案是:先備份數(shù)據(jù),然后強制轉換字符集從UTF8到ZHS16GBK,然后導入備份數(shù)據(jù)。如果不行,才來重新建庫,設置字符集ZHS16GBK,導入備份數(shù)據(jù)。如果這還不行,就把更改字符集從ZHS16GBK到UTF8(這是安全的),再導入備份數(shù)據(jù),恢復到原始狀況。這樣就有可能避開重新建庫的麻煩。1. 備份數(shù)據(jù)庫中所有用戶的數(shù)據(jù)以oracle用戶登陸,執(zhí)行以下命令# export NLS_LANG = “SIMPLIFIED CHINESE_CHINA.UTF8”保持與數(shù)據(jù)庫服務器端一致,這樣在exp導出時,就不會存在字符的轉換了,備份最原始的數(shù)據(jù)。2. 評估UTF8轉換成ZHS16GBK的風險轉換之前,要使用Oracle的csscan工具對數(shù)據(jù)庫掃描,評估字符集轉換前后,數(shù)據(jù)有可能的損壞情況。如果評估情況糟糕,那就絕對要放棄了。先安裝屬于 CSMIG 用戶的一套表和過程。以oracle用戶登陸UNIX,#sqlplus “/ as sysdab”SQL@$ORACLE_HOME/ rdbms/admin/csminst.sqlSQLexit# $ORACLE_HOME\bin\csscan -help可以更清楚如何使用csscan。# $ORACLE_HOME/bin/csscan system/sunday user=mmsc FROMCHAR=UTF8 TOCHAR=ZHS16GBK ARRAY=102400 PROCESS=3 csscan.log以上命令意思是掃描用戶:mmsc中的所有數(shù)據(jù),從字符集UTF8更改為ZHS16GBK的轉換情況。然后得到三個文件:scan.txt、scan.out、scan.err。查看scan.out,scan.err,可以看出mmsc用戶下的所有的數(shù)據(jù)都是可以轉換的,并且沒有出現(xiàn)轉換“Exceptional”的情況,因此可以更放心一點。3. 更改數(shù)據(jù)庫的字符集為ZHS16GBK前面說過,通過命令“Alter Database Characeter Set XXXX”,實現(xiàn)從超集到子集的轉換,在Oracle是不允許的。但是該命令,提供這樣的命令方式:Alter Database Character Set INTERNAL_CONVERT/ INTERNAL_USE XXXX這是Oracle的非公開命令。“在使用這個命令時,Oracle會跳過所有子集及超集的檢查,在任意字符集之間進行強制轉換,所以,使用這個命令時你必須十分小心,你必須清楚這一操作會帶來的風險”。以oracle用戶登陸UNIX,#sqlplus “/ as sysdba”SQL SHUTDOWN IMMEDIATE; SQL STARTUP MOUNT; SQL ALTER SESSION SET SQL_TRACE=TRUE;SQL ALTER SYSTEM ENABLE RESTRICTED SESSION; SQL ALTER SYSTEM SET JOB_QUEUE_PROCESSES=0; SQL ALTER SYSTEM SET AQ_TM_PROCESSES=0; SQL ALTER DATABASE OPEN; SQL ALTER DATABASE CHARACTER SET ZHS16GBK; //如果不使用“INTERNAL_USE”參數(shù),系統(tǒng)會提示出錯://ERROR at line 1://ORA-12712: new character set must be a superset of old character setSQL ALTER SESSION SET SQL_TRACE=FALSE;SQL SHUTDOWN IMMEDIATE; SQL STARTUP;此時,檢查一下數(shù)據(jù)庫的字符集是否更改過來SQL select value$ from props$ where name=’NLS_CHARACTERSET’;VALUE$-----------------ZHS16GBK緊接著檢查一下數(shù)據(jù)庫中簡體中文、繁體中文是否正常,不會出現(xiàn)亂碼。SQLselect spid,spname,spshortname from spinfovisual_hk …...非常不幸,我看到了一堆亂碼,這也證明了Oracle不支持字符集從超集到子集的更改,當時心里很緊張,很怕失敗,從而恢復到原樣。但是根據(jù)以前的驗證,把UTF8下的備份導入到ZHS16GBK中去,是OK的,所以繼續(xù)嘗試。4. 導入備份的用戶數(shù)據(jù)還是以oracle用戶登陸UNIX, 先刪除庫中的用戶mmsc:#sqlplus “/ as sysdba”SQLdrop user mmsc cascade;SQLexit再運行createuser.sql,生成mmsc用戶。然后使用原來的備份文件,導入到mmsc用戶中:注意:先設置NLS_LANG要與當前數(shù)據(jù)庫的一致:ZHS16GBK。這樣,導出時用戶會話的NLS_LANG為UTF8,與原先的數(shù)據(jù)庫字符集一致;現(xiàn)在為ZHS16GBK,與此時的數(shù)據(jù)庫字符集一致。這樣,導入時,就會進行字符轉換。# export NLS_LANG = “SIMPLIFIED CHINESE_CHINA.ZHS16GBK”#imp mmsc/mmsc@mdspdb file=DSMPD113_user_mmsc.dmp ignore=y fromuser=mmsc touser=mmsc馬上查看數(shù)據(jù)庫中簡體、繁體中文,哈哈,沒有亂碼了,一切顯示正常。緊接著進行驗證,也證明了:1個漢字此時只占用2個字符長度。問題解決了!
10年積累的成都做網(wǎng)站、成都網(wǎng)站設計經(jīng)驗,可以快速應對客戶對網(wǎng)站的新想法和需求。提供各種問題對應的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡服務。我雖然不認識你,你也不認識我。但先做網(wǎng)站后付款的網(wǎng)站建設流程,更有鎮(zhèn)康免費網(wǎng)站建設讓你可以放心的選擇與我們合作。
更改當前會話的語言就可以了,執(zhí)行下面這段SQL
--PLSQL中修改當前會話語言環(huán)境
alter session set nls_language='SIMPLIFIED CHINESE' -- 中文
alter session set nls_language='AMERICAN'; -- 英文
以IE為例: Tools - Internet Options - General - Language 點擊 'Add' 按鈕把中文添加的列表里面 點擊 'Move up' 或 'Move down' 按鈕把中文調(diào)整的最上方 WAS管理控制臺頁面,將由英文變?yōu)橹形娘@示。
這是因為Oracle網(wǎng)站采用的是國際化,當你訪問官網(wǎng)時,它會根據(jù)你操作系統(tǒng)默認的區(qū)域和語言選擇相應的下載項,如果你的區(qū)域和語言是中文,它就會下載中文安裝包,一個簡單的辦法是:修改一下默認的“區(qū)域和語言”,將它改為英文即可,在控制面板的區(qū)域和語言選項