oracle linux 修改字符集

  1. select userenv('language') from dual; //查看系統字符集編碼
  2. select * from nls_database_parameters where parameter in ('NLS_CHARCTERSET','NLS_NCHAR_CHARACTERSET');
  3. shutdown immediate
  4. startup
  5. alter session set sql_trace=true;
  6. alter system enable restricted session;
  7. show parameter job_queue_processes;
  8. alter system set job_queue_processes=0;
  9. alter system set aq_tm_processes=0;
  10. alter database character set INTERNAL_USE AL32UTF8;
  11. update props$ set VALUE$='UTF8' where NAME='NLS_NCHAR_CHARACTERSET';

 

 

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

如果系統中已經存在很多數據,建議修改字段長度,因爲修改字符集後原來數據庫表中的漢字全部變成亂碼。如果一定要修改字符集,必須先導出數據,待到字符集修改後再重新導入這些數據。

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

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

修改數據庫字符集爲:ZHS16GBK
查看服務器端字符集SQL > select * from V$NLS_PARAMETERS
Telnet到服務器,執行:$sqlplus /nolog
SQL>conn / 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

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

 

 

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章