資料匯入時報ORA-12899錯誤原因是:由於Oracle字符集不同,漢字佔的長度不同造成的。
字符集的意思是插入的資料長度超出欄位的設定長度,實際長度並不長。
原因:
中文在ZHS16GBK中佔2個位元組,在UTF-8中卻佔3個位元組,所以漢字匯入UTF-8字符集的資料庫就很容易出現欄位長度不夠。
解決辦法:
一個是增加欄位長度,還有就是修改字符集。
特別說明:
如果系統中已經存在很多資料,建議修改欄位長度,因為修改字符集後原來資料庫表中的漢字全部變成亂碼。如果一定要修改字符集,必須先匯出資料,待到字符集修改後再重新匯入這些資料。
具體檢視方法:
檢視字符集的方法可以用PL/SQL DEVELOP ---->Reports---->DBA---->NLS Database Parameters,結果如下圖:
具體解決方法:需要輸入如下命令符。
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
至此,字符集修改完畢。
擴充套件資料:
Oracle的解決之道 :在稅務部門資訊化大集中的規劃之下,建立完整的資訊化架構,以網格作為統一的基礎平臺;然後在網格基礎平臺的基礎之上,進行資料集中;最後從資料集中再到應用集中,實現以最佳化管理為目的,更好地進行業務處理與資訊的接通等服務。
整合現有的各種平臺、系統和資料,建立一個資訊資料總局、省局兩級處理的統一的技術平臺,需要解決以下的問題:資料的採集、資料的儲存和管理、資料的質量控制、資料的靈活展現。
以網格技術構建的基礎平臺,能夠提高硬體的利用率和資源共享,能夠使公司可以透過增加成本元件來向外擴張,還可以減少管理需求等。所以,透過網格基礎平臺,就可以滿足資料的採集、儲存、管理、展現和控制等需求。
參考資料:
資料匯入時報ORA-12899錯誤原因是:由於Oracle字符集不同,漢字佔的長度不同造成的。
字符集的意思是插入的資料長度超出欄位的設定長度,實際長度並不長。
原因:
中文在ZHS16GBK中佔2個位元組,在UTF-8中卻佔3個位元組,所以漢字匯入UTF-8字符集的資料庫就很容易出現欄位長度不夠。
解決辦法:
一個是增加欄位長度,還有就是修改字符集。
特別說明:
如果系統中已經存在很多資料,建議修改欄位長度,因為修改字符集後原來資料庫表中的漢字全部變成亂碼。如果一定要修改字符集,必須先匯出資料,待到字符集修改後再重新匯入這些資料。
具體檢視方法:
檢視字符集的方法可以用PL/SQL DEVELOP ---->Reports---->DBA---->NLS Database Parameters,結果如下圖:
具體解決方法:需要輸入如下命令符。
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
至此,字符集修改完畢。
擴充套件資料:
Oracle的解決之道 :在稅務部門資訊化大集中的規劃之下,建立完整的資訊化架構,以網格作為統一的基礎平臺;然後在網格基礎平臺的基礎之上,進行資料集中;最後從資料集中再到應用集中,實現以最佳化管理為目的,更好地進行業務處理與資訊的接通等服務。
整合現有的各種平臺、系統和資料,建立一個資訊資料總局、省局兩級處理的統一的技術平臺,需要解決以下的問題:資料的採集、資料的儲存和管理、資料的質量控制、資料的靈活展現。
以網格技術構建的基礎平臺,能夠提高硬體的利用率和資源共享,能夠使公司可以透過增加成本元件來向外擴張,還可以減少管理需求等。所以,透過網格基礎平臺,就可以滿足資料的採集、儲存、管理、展現和控制等需求。
參考資料: