程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> 關於Oracle數據庫 >> Oracle] 淺析令人抓狂的ORA-01555問題

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

編輯:關於Oracle數據庫
    首先要說明的一點是:ORA-01555錯誤是一個“安全”的錯誤,它不會造成數據丟失或損壞,只是會讓接收到該錯誤的查詢無法繼續。以下就是對發生ORA-01555錯誤的原因進行了介紹,需要的朋友可以參考下  

    因此,在數據庫的日常維護工作中,如果只是一次兩次碰到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包掃描相關對象。

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved