ORA-00001: unique constraint violated並不一定是主鍵沖突


原文鏈接:http://blog.163.com/jet_it_life/blog/static/205097083201301410303931/

原文內容:

收到一位測試人員RAISE的JIRA,說在某張表上INSERT不了數據,報ORA-00001: unique constraint violated的錯誤,但是仔細核查了一下,並沒有發現有重復的數據,讓幫忙檢查一下是什么問題。
僅僅看錯誤,應該是數據沖突引起的。但有一點比較奇怪的是錯誤中提示的違反的約束是一個索引,而這個索引並不是唯一索引!將這個索引DROP后,ORA-00001依然存在,但是這次換了一個索引!而這個索引依然不是唯一索引!再將這個索引DROP后再進行INSERT,問題的本質就暴露出來了:
ERROR at line 1: 
ORA-00600: internal error code, arguments: [6002], [0], [227], [2], [0], [], [], [] 
600的錯誤,可能是表或表上的索引數據有壞塊或者表或表的索引結構存在問題,嘗試分析表及索引的結構:
SQL> ANALYZE TABLE #.#  VALIDATE STRUCTURE CASCADE; 
ANALYZE TABLE #.# VALIDATE STRUCTURE CASCADE 

ERROR at line 1: 
ORA-01499: table/index cross reference failure - see trace file 
已經基本可以確定問題在表結構及其索引,嘗試對表及相關索引進行重建:
SQL> alter TABLE #.# move; 


Table altered. 
SQL> alter index #.# REBUILD;


Index altered. 
...
重建完表和索引后,終於正常INSERT了。


最近幾天,也遇到了一個Oracle的ORA-00001異常,查詢表中的數據,也沒有沖突的主鍵,就是偶爾保存數據就會出錯,暫時還沒找到原因,先mark一下


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM