修改Oracle字元集

來源:互聯網
上載者:User

標籤:str   session   manager   查看   系統   eve   字元   建議   設定   

資料匯入時報ORA-12899錯誤,即插入的資料長度超出欄位的設定長度,實際長度並不長,這是由於Oracle字元集不同,漢字占的長度不同造成的。中文在ZHS16GBK中佔2個位元組,在UTF-8中卻佔3個位元組,所以漢字匯入UTF-8字元集的資料庫就很容易出現欄位長度不夠,解決辦法,一個是增加欄位長度,還有就是修改字元集。

如果系統中已經存在很多資料,建議修改欄位長度,因為修改字元集後原來資料庫表中的漢字全部變成亂碼。如果一定要修改字元集,必須先匯出資料,待到字元集修改後再重新匯入這些資料。

查看字元集的方法可以用PL/SQL DEVELOP ---->Reports---->DBA---->NLS Database Parameters,結果如:

如所示,字元集是UTF-8,修改字元集的方法如下:

修改資料庫字元集為:ZHS16GBK

開始->運行->cmd,輸入sqlplus system/[email protected] as SYSDBA
若此時資料庫伺服器已啟動,則先執行 SHUTDOWN IMMEDIATE 命令關閉資料庫伺服器,
然後執行以下命令:
SQL>shutdown immediate
SQL>STARTUP MOUNT
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;
ERROR at line 1:ORA-12721: operation cannot execute when other sessions are active
若出現上面的錯誤,使用下面的辦法進行修改,使用INTERNAL_USE可以跳過超集的檢查:
SQL>ALTER DATABASE CHARACTER SET INTERNAL_USE ZHS16GBK;
SQL>SHUTDOWN IMMEDIATE
SQL>STARTUP

至此,字元集修改完畢,再查字元集,結果如下:

修改Oracle字元集

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.