oracle 修改字符集

urgel_babay發表於2016-02-29
提醒:修改字符集,會造成以前的資料記錄亂碼,修改之後只能從修改後對以後插入的資料有效。
檢視資料庫的字符集


col parameter for a40
col value for a40
set lines 200
select * from nls_database_parameters where PARAMETER='NLS_CHARACTERSET';

可按以下方法修改(建議先備份)
---修改字符集
  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;
  SQL>ALTER DATABASE national CHARACTER SET ZHS16GBK;
  SQL>SHUTDOWN IMMEDIATE;
  SQL>STARTUP

有可能會遇見報錯如下:

點選(此處)摺疊或開啟

  1. SQL> ALTER DATABASE CHARACTER SET ZHS16GBK
  2. *
  3. ERROR at line 1:
  4. ORA-12712: new character set must be a superset of old character set
  5. SQL> ALTER DATABASE national CHARACTER SET ZHS16GBK
  6. *
  7. ERROR at line 1:
  8. ORA-12714: invalid national character set specified

解決辦法:

點選(此處)摺疊或開啟

  1. SQL> ALTER DATABASE character set INTERNAL_USE ZHS16GBK;

  2. Database altered.

alter database character set internal_use &charset;
alter database national character set internal_use &ncharset;
INTERNAL_USE是沒有寫在文件中的引數,用於強制完成字符集轉化,

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/30936525/viewspace-2016719/,如需轉載,請註明出處,否則將追究法律責任。

相關文章