真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

oracle怎么切換中文 oracle數(shù)據(jù)庫(kù)語(yǔ)言設(shè)成中文

如何將Oracle數(shù)據(jù)庫(kù)中的Unicode轉(zhuǎn)換為中文

過(guò)程名 : decodeUnicode2CN

目前創(chuàng)新互聯(lián)公司已為超過(guò)千家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)站空間、網(wǎng)站改版維護(hù)、企業(yè)網(wǎng)站設(shè)計(jì)、城子河網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶(hù)導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶(hù)和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。

功能 : 將unicode編碼格式轉(zhuǎn)換成中文

輸入?yún)?shù) :text :unicode編碼內(nèi)容

輸出參數(shù) :中文輸出

=======================================================

FUNCTION DECODEUNICODE2CN(TEXT IN VARCHAR2) RETURN VARCHAR2 IS

V_SQL VARCHAR2(32765); --編碼轉(zhuǎn)換sql

TEXT_BUFFER VARCHAR2(32765); --輸出中文

BEGIN

V_SQL := 'select unistr(REPLACE(''' || TEXT ||

''',''\u'',''\'')) from dual ';

EXECUTE IMMEDIATE V_SQL

INTO TEXT_BUFFER;

RETURN TEXT_BUFFER;

END;

oracle primavera p6怎樣修改語(yǔ)言

在P6 PPM 7.0 版本中需要先登陸軟件,在菜單欄中選擇Tools ,在下拉菜單中選擇 Set Language...? 會(huì)出現(xiàn)一個(gè)語(yǔ)言選擇的窗口,然后點(diǎn)擊您需要的語(yǔ)言。例如:Chinese Simplified(簡(jiǎn)體中文)。

如圖所示:

如何實(shí)現(xiàn)oracle數(shù)據(jù)庫(kù)中英文字符集轉(zhuǎn)換

如何更改Oracle字符集國(guó)內(nèi)最常用的Oracle字符集ZHS16GBK(GBK 16-bit Simplified Chinese)能夠支持繁體中文,并且按照2個(gè)字符長(zhǎng)度存儲(chǔ)一個(gè)漢字。UTF8字符集是多字節(jié)存儲(chǔ),1個(gè)漢字(簡(jiǎn)體、繁體)有時(shí)采用3個(gè)字符長(zhǎng)度存儲(chǔ)。Oracle支持字符集的更改,但是UTF8是Oracle中最大的字符集,也就是說(shuō)UTF8是ZHS16GBK的嚴(yán)格超集。對(duì)于子集到超集的轉(zhuǎn)換,Oracle是允許的,但是對(duì)于超集到子集的轉(zhuǎn)換是不允許的。一般對(duì)于超集到子集的轉(zhuǎn)換,建議是通過(guò)dbca刪除原來(lái)的數(shù)據(jù)庫(kù),重新再建庫(kù),選擇正確的字符集,然后導(dǎo)入備份。我的方案是:先備份數(shù)據(jù),然后強(qiáng)制轉(zhuǎn)換字符集從UTF8到ZHS16GBK,然后導(dǎo)入備份數(shù)據(jù)。如果不行,才來(lái)重新建庫(kù),設(shè)置字符集ZHS16GBK,導(dǎo)入備份數(shù)據(jù)。如果這還不行,就把更改字符集從ZHS16GBK到UTF8(這是安全的),再導(dǎo)入備份數(shù)據(jù),恢復(fù)到原始狀況。這樣就有可能避開(kāi)重新建庫(kù)的麻煩。1. 備份數(shù)據(jù)庫(kù)中所有用戶(hù)的數(shù)據(jù)以oracle用戶(hù)登陸,執(zhí)行以下命令# export NLS_LANG = “SIMPLIFIED CHINESE_CHINA.UTF8”保持與數(shù)據(jù)庫(kù)服務(wù)器端一致,這樣在exp導(dǎo)出時(shí),就不會(huì)存在字符的轉(zhuǎn)換了,備份最原始的數(shù)據(jù)。2. 評(píng)估UTF8轉(zhuǎn)換成ZHS16GBK的風(fēng)險(xiǎn)轉(zhuǎn)換之前,要使用Oracle的csscan工具對(duì)數(shù)據(jù)庫(kù)掃描,評(píng)估字符集轉(zhuǎn)換前后,數(shù)據(jù)有可能的損壞情況。如果評(píng)估情況糟糕,那就絕對(duì)要放棄了。先安裝屬于 CSMIG 用戶(hù)的一套表和過(guò)程。以oracle用戶(hù)登陸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以上命令意思是掃描用戶(hù):mmsc中的所有數(shù)據(jù),從字符集UTF8更改為ZHS16GBK的轉(zhuǎn)換情況。然后得到三個(gè)文件:scan.txt、scan.out、scan.err。查看scan.out,scan.err,可以看出mmsc用戶(hù)下的所有的數(shù)據(jù)都是可以轉(zhuǎn)換的,并且沒(méi)有出現(xiàn)轉(zhuǎn)換“Exceptional”的情況,因此可以更放心一點(diǎn)。3. 更改數(shù)據(jù)庫(kù)的字符集為ZHS16GBK前面說(shuō)過(guò),通過(guò)命令“Alter Database Characeter Set XXXX”,實(shí)現(xiàn)從超集到子集的轉(zhuǎn)換,在Oracle是不允許的。但是該命令,提供這樣的命令方式:Alter Database Character Set INTERNAL_CONVERT/ INTERNAL_USE XXXX這是Oracle的非公開(kāi)命令?!霸谑褂眠@個(gè)命令時(shí),Oracle會(huì)跳過(guò)所有子集及超集的檢查,在任意字符集之間進(jìn)行強(qiáng)制轉(zhuǎn)換,所以,使用這個(gè)命令時(shí)你必須十分小心,你必須清楚這一操作會(huì)帶來(lái)的風(fēng)險(xiǎn)”。以oracle用戶(hù)登陸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)會(huì)提示出錯(cuò)://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í),檢查一下數(shù)據(jù)庫(kù)的字符集是否更改過(guò)來(lái)SQL select value$ from props$ where name=’NLS_CHARACTERSET’;VALUE$-----------------ZHS16GBK緊接著檢查一下數(shù)據(jù)庫(kù)中簡(jiǎn)體中文、繁體中文是否正常,不會(huì)出現(xiàn)亂碼。SQLselect spid,spname,spshortname from spinfovisual_hk …...非常不幸,我看到了一堆亂碼,這也證明了Oracle不支持字符集從超集到子集的更改,當(dāng)時(shí)心里很緊張,很怕失敗,從而恢復(fù)到原樣。但是根據(jù)以前的驗(yàn)證,把UTF8下的備份導(dǎo)入到ZHS16GBK中去,是OK的,所以繼續(xù)嘗試。4. 導(dǎo)入備份的用戶(hù)數(shù)據(jù)還是以oracle用戶(hù)登陸UNIX, 先刪除庫(kù)中的用戶(hù)mmsc:#sqlplus “/ as sysdba”SQLdrop user mmsc cascade;SQLexit再運(yùn)行createuser.sql,生成mmsc用戶(hù)。然后使用原來(lái)的備份文件,導(dǎo)入到mmsc用戶(hù)中:注意:先設(shè)置NLS_LANG要與當(dāng)前數(shù)據(jù)庫(kù)的一致:ZHS16GBK。這樣,導(dǎo)出時(shí)用戶(hù)會(huì)話的NLS_LANG為UTF8,與原先的數(shù)據(jù)庫(kù)字符集一致;現(xiàn)在為ZHS16GBK,與此時(shí)的數(shù)據(jù)庫(kù)字符集一致。這樣,導(dǎo)入時(shí),就會(huì)進(jìn)行字符轉(zhuǎn)換。# export NLS_LANG = “SIMPLIFIED CHINESE_CHINA.ZHS16GBK”#imp mmsc/mmsc@mdspdb file=DSMPD113_user_mmsc.dmp ignore=y fromuser=mmsc touser=mmsc馬上查看數(shù)據(jù)庫(kù)中簡(jiǎn)體、繁體中文,哈哈,沒(méi)有亂碼了,一切顯示正常。緊接著進(jìn)行驗(yàn)證,也證明了:1個(gè)漢字此時(shí)只占用2個(gè)字符長(zhǎng)度。問(wèn)題解決了!

ORACLE顯示中文為亂碼,怎么修改?

在Redhat上安裝Oracle10g沒(méi)有設(shè)定字符集,采用的是操作系統(tǒng)默認(rèn)字符集:WE8ISO8859P1,將字符集修改為:ZHS16GBK。由于過(guò)程不可逆,首先需要備份數(shù)據(jù)庫(kù)。\x0d\x0a1.數(shù)據(jù)庫(kù)全備\x0d\x0a\x0d\x0a2.查詢(xún)當(dāng)前字符集\x0d\x0aSQLselect*fromnls_database_parameterswhereparameter='NLS_CHARACTERSET';\x0d\x0aPARAMETERVALUE\x0d\x0a--------------------------------------------------------------------------------\x0d\x0aNLS_CHARACTERSETWE8ISO8859P1\x0d\x0a\x0d\x0a3.關(guān)閉數(shù)據(jù)庫(kù)\x0d\x0aSQLshutdownimmediate\x0d\x0aDatabaseclosed.\x0d\x0aDatabasedismounted.\x0d\x0aORACLEinstanceshutdown.\x0d\x0a\x0d\x0a4.啟動(dòng)數(shù)據(jù)庫(kù)到mount狀態(tài)\x0d\x0aSQLstartupmount\x0d\x0aORACLEinstancestarted.\x0d\x0aTotalSystemGlobalArea205520896bytes\x0d\x0aFixedSize1266608bytes\x0d\x0aVariableSize100666448bytes\x0d\x0aDatabaseBuffers100663296bytes\x0d\x0aRedoBuffers2924544bytes\x0d\x0aDatabasemounted.\x0d\x0a\x0d\x0a5.限制session\x0d\x0aSQLaltersystemenablerestrictedsession;\x0d\x0aSystemaltered.\x0d\x0a\x0d\x0a6.查詢(xún)相關(guān)參數(shù)并修改\x0d\x0aSQLshowparameterjob_queue_processes;\x0d\x0aNAMETYPEVALUE\x0d\x0a-----------------------------------------------------------------------------\x0d\x0ajob_queue_processesinteger10\x0d\x0a\x0d\x0aSQLshowparameteraq_tm_processes;\x0d\x0aNAMETYPEVALUE\x0d\x0a-----------------------------------------------------------------------------\x0d\x0aaq_tm_processesinteger0\x0d\x0a\x0d\x0aSQLaltersystemsetjob_queue_processes=0;\x0d\x0aSystemaltered.\x0d\x0a\x0d\x0a7.打開(kāi)數(shù)據(jù)庫(kù)\x0d\x0aSQLalterdatabaseopen;\x0d\x0aDatabasealtered.\x0d\x0a\x0d\x0a8.修改字符集\x0d\x0aSQLalterdatabasecharactersetZHS16GBK;\x0d\x0aalterdatabasecharactersetZHS16GBK\x0d\x0a*\x0d\x0aERRORatline1:\x0d\x0aORA-12712:newcharactersetmustbeasupersetofoldcharacterset\x0d\x0a\x0d\x0a出現(xiàn)錯(cuò)誤提示,新字符集必須是老字符集的超集,也就原來(lái)字符集是新字符集的子集,可以再Oracle官方文檔上查詢(xún)字符集包含關(guān)系。下面使用Oracle內(nèi)部命令internal_use,跳過(guò)超集檢查,生產(chǎn)環(huán)境不建議使用此方法。\x0d\x0a\x0d\x0aSQLalterdatabasecharactersetinternal_useZHS16GBK;\x0d\x0aDatabasealtered.\x0d\x0a\x0d\x0a9.查詢(xún)當(dāng)前字符集\x0d\x0aSQLselect*fromnls_database_parameterswhereparameter='NLS_CHARACTERSET';\x0d\x0aPARAMETERVALUE\x0d\x0a--------------------------------------------------------------------------------\x0d\x0aNLS_CHARACTERSETZHS16GBK\x0d\x0a\x0d\x0a10.關(guān)閉數(shù)據(jù)庫(kù)\x0d\x0aSQLshutdownimmediate\x0d\x0aDatabaseclosed.\x0d\x0aDatabasedismounted.\x0d\x0aORACLEinstanceshutdown.\x0d\x0a\x0d\x0a11.啟動(dòng)數(shù)據(jù)庫(kù)到mount狀態(tài)\x0d\x0aSQLstartupmount\x0d\x0aORACLEinstancestarted.\x0d\x0aTotalSystemGlobalArea205520896bytes\x0d\x0aFixedSize1266608bytes\x0d\x0aVariableSize100666448bytes\x0d\x0aDatabaseBuffers100663296bytes\x0d\x0aRedoBuffers2924544bytes\x0d\x0aDatabasemounted.\x0d\x0a\x0d\x0a12.將相關(guān)參數(shù)改回原來(lái)值\x0d\x0aSQLaltersystemsetjob_queue_processes=10;\x0d\x0aSystemaltered.\x0d\x0a\x0d\x0a13.打開(kāi)數(shù)據(jù)庫(kù)\x0d\x0aSQLalterdatabaseopen;\x0d\x0aDatabasealtered.


新聞名稱(chēng):oracle怎么切換中文 oracle數(shù)據(jù)庫(kù)語(yǔ)言設(shè)成中文
文章出自:http://weahome.cn/article/hpidoe.html

其他資訊

在線咨詢(xún)

微信咨詢(xún)

電話咨詢(xún)

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部