[Oracle] 淺析令人抓狂的ORA-01555問題_oracle

來源:互聯網
上載者:User

因此,在資料庫的日常維護工作中,如果只是一次兩次碰到ORA-01555錯誤,一般都先忽略,但是如果經常碰到該錯誤,則要進行一些調整以避免該錯誤的再次發生。

1. 為什麼會產生ORA-01555錯誤?
這個錯誤是由資料庫的讀一致性(Read consistency)引起的,當查詢需要訪問被修改的資料時,它會到undo裡訪問該資料的前鏡像,如果該前鏡像已被覆蓋,查詢語句就會返回ORA-01555的錯誤。

2. 導致ORA-01555錯誤的主要原因有哪些?
1) undo太小
比較直觀的解決方案是DBA告訴資料庫應用最長的查詢需要多長時間,並把UNDO_RETENTION設為這個值,同時相應增大undo資料表空間大小。
但要從根本上解決undo太小問題,還得從應用端代碼調優入手,減少查詢的已耗用時間。

2) 延遲的塊清除
這種情況比較少見,特別是在OLTP系統裡,在OLAP系統裡可能會碰到,解決方案是在每次大量的insert或update之後,記得用DBMS_STATS包掃描相關對象。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.