1.數據庫死鎖的現象程序在執行的過程中,點擊確定或保存按鈕,程序沒有響應,也沒有出現報錯。
創新互聯致力于成都網站制作、做網站,成都網站設計,集團網站建設等服務標準化,推過標準化降低中小企業的建站的成本,并持續提升建站的定制化服務水平進行質量交付,讓企業網站從市場競爭中脫穎而出。 選擇創新互聯,就選擇了安全、穩定、美觀的網站建設服務!
2.死鎖的原理當對于數據庫某個表的某一列做更新或刪除等操作,執行完畢后該條語句不提交,另一條對于這一列數據做更新操作的語句在執行的...
3.死鎖的定位方法通過檢查數據庫表,能夠檢查出是哪一條語句被死鎖,產生死鎖的機器是哪一臺。 ...
4.死鎖的解決方法 一般情況下,只要將產生死鎖的語句提交就可以了,但是在實際的執行過程中.
例子?
事務A 事務B
時間點C 請求排他鎖A 請求排他鎖B
時間點D 請求排他鎖B 請求排他鎖A
這是個環路等待的例子吧,結局是事務A一致等鎖B的釋放,而事務B一致等鎖A的釋放
解決的方法 是 重寫代碼,2個鎖一起請求,而不是分開請求
在對指定表做append操作,其他再做truncate時候,會產生鎖表,如下驗證步驟,
1、創建測試表,
create table test_lock(id number, value varchar2(200));
2、執行append語句;并且不做提交,insert /*+append*/ into test_lock values(1,1);
3、再次執行清表語句,truncate table test_lock;報鎖表錯誤,
4、查看鎖表語句,發現被鎖表,
select b.object_name, t.*
from v$locked_object t, user_objects b
where t.object_id = b.object_id
DML鎖又可以分為,行鎖、表鎖、死鎖
-行鎖:當事務執行數據庫插入、更新、刪除操作時,該事務自動獲得操作表中操作行的排它鎖。
-表級鎖:當事務獲得行鎖后,此事務也將自動獲得該行的表鎖(共享鎖),以防止其它事務進行DDL語句影響記錄行的更新。事務也可以在進行過程中獲得共享鎖或排它鎖,只有當事務顯示使用LOCK TABLE語句顯示的定義一個排它鎖時,事務才會獲得表上的排它鎖,也可使用LOCK TABLE顯示的定義一個表級的共享鎖(LOCK TABLE具體用法請參考相關文檔)。
-死鎖:當兩個事務需要一組有沖突的鎖,而不能將事務繼續下去的話,就出現死鎖。
如事務1在表A行記錄#3中有一排它鎖,并等待事務2在表A中記錄#4中排它鎖的釋放,而事務2在表A記錄行#4中有一排它鎖,并等待事務1在表A中記錄#3中排它鎖的釋放,事務1與事務2彼此等待,因此就造成了死鎖。死鎖一般是因拙劣的事務設計而產生。
死鎖只能使用SQL下:alter system kill session "sid,serial#";或者使用相關操作系統kill進程的命令,如UNIX下kill -9 sid,或者使用其它工具殺掉死鎖進程。
+DDL鎖又可以分為:排它DDL鎖、共享DDL鎖、分析鎖
-排它DDL鎖:創建、修改、刪除一個數據庫對象的DDL語句獲得操作對象的 排它鎖。如使用alter table語句時,為了維護數據的完成性、一致性、合法性,該事務獲得一排它DDL鎖。
-共享DDL鎖:需在數據庫對象之間建立相互依賴關系的DDL語句通常需共享獲得DDL鎖。
如創建一個包,該包中的過程與函數引用了不同的數據庫表,當編譯此包時,該事務就獲得了引用表的共享DDL鎖。
-分析鎖:ORACLE使用共享池存儲分析與優化過的SQL語句及PL/SQL程序,使運行相同語句的應用速度更快。一個在共享池中緩存的對象獲得它所引用數據庫對象的分析鎖。分析鎖是一種獨特的DDL鎖類型,ORACLE使用它追蹤共享池對象及它所引用數據庫對象之間的依賴關系。當一個事務修改或刪除了共享池持有分析鎖的數據庫對象時,ORACLE使共享池中的對象作廢,下次在引用這條SQL/PLSQL語句時,ORACLE重新分析編譯此語句。
一般情況只發生鎖超時,就是一個進程需要訪問數據庫表或者字段的時候,另外一個程序正在執行帶鎖的訪問(比如修改數據),那么這個進程就會等待,當等了很久鎖還沒有解除的話就會鎖超時,報告一個系統錯誤,拒絕執行相應的SQL操作。發生死鎖的情況比較少,比如一個進程需要訪問兩個資源(數據庫表或者字段),當獲取一個資源的時候進程就對它執行鎖定,然后等待下一個資源空閑,這時候如果另外一個進程也需要兩個資源,而已經獲得并鎖定了第二個資源,那么就會死鎖,因為當前進程鎖定第一個資源等待第二個資源,而另外一個進程鎖定了第二個資源等待第一個資源,兩個進程都永遠得不到滿足。
erp100.com
當前文章:oracle如何造成死鎖,oracle死鎖解決方法
本文網址:http://m.kartarina.com/article46/hegjhg.html
成都網站建設公司_創新互聯,為您提供定制開發、搜索引擎優化、商城網站、標簽優化、網站排名、定制網站
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯