原文鏈接: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一下