ORA-00001: unique constraint (...) violated並不一定是資料衝突

Jet_Zhang發表於2015-05-12
收到一位測試人員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了。

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

相關文章