選單

DMP檔案匯入過程中報錯

問題起始:同樣的檔案導另一庫報錯

問題根源:資料庫服務端字符集問題

問題解決:AL32UTF8轉換為ZHX16GBK即可

資料匯入時報ORA-12899錯誤,即插入的資料長度超出欄位的設定長度,實際長度並不長,這是由於Oracle字符集不同,漢字佔的長度不同造成的。中文在ZHS16GBK中佔2個位元組,在UTF-8中卻佔3個位元組,所以漢字匯入UTF-8字符集的資料庫就很容易出現欄位長度不夠,解決辦法,一個是增加欄位長度,還有就是修改字符集。如果系統中已經存在很多資料,建議修改欄位長度,因為修改字符集後原來資料庫表中的漢字全部變成亂碼。如果一定要修改字符集,必須先匯出資料,待到字符集修改後再重新匯入這些資料。如上圖所示,字符集是UTF-8,修改字符集的方法如下:修改資料庫字符集為:ZHS16GBK檢視伺服器端字符集SQL > select * from V$NLS_PARAMETERS; Telnet到伺服器oracle使用者登入,執行:sqlplus /nologSQL>conn / as sysdba若此時資料庫伺服器已啟動,則先執行 SHUTDOWN IMMEDIATE 命令關閉資料庫伺服器,然後執行以下命令:SQL>shutdown immediateSQL>STARTUP MOUNTSQL>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 IMMEDIATESQL>STARTUP

重新執行SQL > select * from V$NLS_PARAMETERS; 字符集變更完成。

DMP檔案匯入過程中報錯