[Oracle] 淺析令人抓狂的ORA-01555問題
因此,在數(shù)據(jù)庫的日常維護(hù)工作中,如果只是一次兩次碰到ORA-01555錯誤,一般都先忽略,但是如果經(jīng)常碰到該錯誤,則要進(jìn)行一些調(diào)整以避免該錯誤的再次發(fā)生。
1. 為什么會產(chǎn)生ORA-01555錯誤?
這個錯誤是由數(shù)據(jù)庫的讀一致性(Read consistency)引起的,當(dāng)查詢需要訪問被修改的數(shù)據(jù)時,它會到undo里訪問該數(shù)據(jù)的前鏡像,如果該前鏡像已被覆蓋,查詢語句就會返回ORA-01555的錯誤。
2. 導(dǎo)致ORA-01555錯誤的主要原因有哪些?
1) undo太小
比較直觀的解決方法是DBA告訴數(shù)據(jù)庫應(yīng)用最長的查詢需要多長時間,并把UNDO_RETENTION設(shè)為這個值,同時相應(yīng)增大undo表空間大小。
但要從根本上解決undo太小問題,還得從應(yīng)用端代碼調(diào)優(yōu)入手,減少查詢的運(yùn)行時間。
2) 延遲的塊清除
這種情況比較少見,特別是在OLTP系統(tǒng)里,在OLAP系統(tǒng)里可能會碰到,解決方法是在每次大量的insert或update之后,記得用DBMS_STATS包掃描相關(guān)對象。
相關(guān)文章
oracle中如何獲得數(shù)據(jù)庫的DBID信息
在進(jìn)行數(shù)據(jù)庫恢復(fù)的過程中,很多時候我們需要知道Oracle數(shù)據(jù)庫的DBID,通常有以下幾種方法可以獲得數(shù)據(jù)庫的DBID2013-09-09Oracle數(shù)據(jù)庫設(shè)置任務(wù)計劃備份一周的備份記錄
這篇文章介紹了Oracle數(shù)據(jù)庫下通過任務(wù)計劃備份一周的記錄的批處理代碼,需要的朋友可以參考下2013-08-08Oracle使用fy_recover_data恢復(fù)truncate刪除的數(shù)據(jù)
這篇文章主要介紹了Oracle使用fy_recover_data恢復(fù)truncate刪除的數(shù)據(jù),文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的朋友可以參考一下2022-07-07Oracle數(shù)據(jù)庫的備份及恢復(fù)策略研究
Oracle數(shù)據(jù)庫的備份及恢復(fù)策略研究...2007-03-03日常收集整理oracle trunc 函數(shù)處理日期格式(很實用)
關(guān)于oracle trunc函數(shù)小編日常收集整理了些,下面把oracle trunc 函數(shù)處理日期格式的相關(guān)介紹分享給大家,感興趣的朋友參考下2015-10-10Oracle中多表關(guān)聯(lián)批量插入批量更新與批量刪除操作
這篇文章主要介紹了Oracle中多表關(guān)聯(lián)批量插入,批量更新與批量刪除操作,本文通過實例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-12-12