oracle中死鎖是什么
死鎖(Deadlock),這里指的是進(jìn)程死鎖,是個計(jì)算機(jī)技術(shù)名詞。它是操作系統(tǒng)或軟件運(yùn)行的一種狀態(tài):在多任務(wù)系統(tǒng)下,當(dāng)一個或多個進(jìn)程等待系統(tǒng)資源,而資源又被進(jìn)程本身或其它進(jìn)程占用時,就形成了死鎖。由于資源占用是互斥的,當(dāng)某個進(jìn)程提出申請資源后,使得有關(guān)進(jìn)程在無外力協(xié)助下,永遠(yuǎn)分配不到必需的資源而無法繼續(xù)運(yùn)行,這就產(chǎn)生了一種特殊現(xiàn)象。
如何解決ORACLE死鎖的問題
死鎖產(chǎn)生的原因
兩個事務(wù)更新同一個表,并且同時每個事務(wù)要更新的數(shù)據(jù)正在被另外一個事務(wù)所鎖定。因?yàn)閮蓚€事務(wù)在相互等待資源,兩個事務(wù)都無法繼續(xù)下去直到ORACLE產(chǎn)生一個DEADLOCK的錯誤。
ORACLE在檢測到發(fā)生死鎖后,會自動回滾TRANSACTION1中的update emp set sal = sal * 1 where empno = 2000,但是事務(wù)中的第一個語句不會回滾,必須用戶自己提交ROLLBACK操作。
如果在應(yīng)用程序設(shè)計(jì)上可以撲獲DEADLOCK的錯誤,然后使用應(yīng)用程序級別的事務(wù)回滾來解決死鎖。
解決:
此錯誤主要是由于多個進(jìn)程訪問同一數(shù)據(jù)庫時,其中每個進(jìn)程擁有的鎖都是其他進(jìn)程所需的,由此造成每個進(jìn)程都無法繼續(xù)下去。簡單的說,進(jìn)程A等待進(jìn)程B釋放他的資源,B又等待A釋放他的資源,這樣就互相等待,從而形成的.在發(fā)現(xiàn)該問題出現(xiàn)后,應(yīng)當(dāng)及時查看數(shù)據(jù)庫是否自動把死鎖進(jìn)程中的一個結(jié)束,若沒有就應(yīng)當(dāng)手動的殺掉其中一個進(jìn)程,以免影響數(shù)據(jù)庫的正常穩(wěn)定運(yùn)行.