一般情況只發生鎖超時,就是一個進程需要訪問數據庫表或者字段的時候,另外一個程序正在執行帶鎖的訪問(比如修改數據),那么這個進程就會等待,當等了很久鎖還沒有解除的話就會鎖超時,報告一個系統錯誤,拒絕執行相應的SQL操作。發生死鎖的情況比較少,比如一個進程需要訪問兩個資源(數據庫表或者字段),當獲取一個資源的時候進程就對它執行鎖定,然后等待下一個資源空閑,這時候如果另外一個進程也需要兩個資源,而已經獲得并鎖定了第二個資源,那么就會死鎖,因為當前進程鎖定第一個資源等待第二個資源,而另外一個進程鎖定了第二個資源等待第一個資源,兩個進程都永遠得不到滿足。
成都創新互聯公司是專業的永嘉網站建設公司,永嘉接單;提供成都網站設計、網站建設,網頁設計,網站設計,建網站,PHP網站建設等專業做網站服務;采用PHP框架,可快速的進行永嘉網站開發網頁制作和功能擴展;專業做搜索引擎喜愛的網站,專業的做網站團隊,希望更多企業前來合作!
erp100.com
大家通常會遇到這種現象,在自己web項目首頁使用用戶名,密碼登陸系統時,始終停留在本頁面,無法進入系統,或是在執行某些操作后,系統一直處在等待狀態,不出結果,后臺也無任何錯誤提醒。此時,很大的可能就是數據庫鎖等待,所要查詢的包含用戶名和密碼的表或是用戶正操作的表正在被占用造成的。鎖等待的現象:程序在執行的過程中,點擊確定或保存按鈕,程序沒有響應,也沒有出現報錯。網上有很多人把這種現象稱為死鎖,是不合理的。此時的oracle并未發生任何死鎖現象,只是它一直在等待使用者前一個操作的提交。產生鎖等待的原因:當對于數據庫某個表的某一列做更新或刪除等操作,執行完畢后該條語句不提交,另一條對于這一列數據做更新操作的語句在執行的時候就會處于等待狀態,此時的現象是這條語句一直在執行,但一直沒有執行成功,也沒有報錯。鎖等待定位方法:Sql代碼select sql_text from v$sql where hash_value in(select sql_hash_value from v$session where sid in(select session_id from v$locked_object))Sql代碼SELECT s.username,l.OBJECT_ID,l.SESSION_ID,s.SERIAL#,l.ORACLE_USERNAME,l.OS_USER_NAME,l.PROCESSFROM V$LOCKED_OBJECT l,V$SESSION S WHERE l.SESSION_ID=S.SID;以上兩種方法皆可以,不過查詢出來的屬性不同,可以根據個人需要選擇。其中有一種方法速度較快,但我忘記是哪一種了,您若遇到數據庫出現和鎖等待相符的現象,可以用這兩種方法查詢試一下,若得到結果,則說明確實發生鎖等待現象了。單個解決鎖等待的方法:Sql代碼alter system kill session 'sid, serial#'其中的sid和serial可以通過上面鎖等待定位方法的第二個方法得到,sid對應SESSION_ID,serial#對應SERIAL#。例如:Sql代碼alter system kill session '130,2';我通常會遇到上千個鎖,實在沒辦法一個一個的kill掉了,所以我通常使用下述批量解鎖方法。批量解鎖方法:注:此方法應在plsql中運行Sql代碼declare cursor mycur isselect b.sid,b.serial#from v$locked_object a,v$session bwhere a.session_id = b.sid group by b.sid,b.serial#;beginfor cur in mycur loopexecute immediate ( 'alter system kill session '''||cur.sid || ','|| cur.SERIAL# ||''' ');end loop;end;
不同的事務同一時間操作同一張表的同一條記錄的時候會造成死鎖。
解鎖語句
select object_name 對象名稱,machine as 主機,
s.program 程序,s.sid,s.serial#,p.spid as OS進程號
from v$locked_object l,dba_objects o ,v$session s ,v$process p
where l.object_id=o.object_id
and l.session_id=s.sid
and s.paddr=p.addr;
ALTER SYSTEM KILL SESSION '1377,4392' --依次填入SID和SERIAL#解鎖
1 使用事務時,盡量縮短事務的邏輯處理過程,及早提交或回滾事務; (細化處理邏輯,執行一段邏輯后便回滾或者提交,然后再執行其它邏輯,直到事物執行完畢提交)
2 設置死鎖超時參數為合理范圍,如:3分鐘-10分種;超過時間,自動放棄本次操作,避免進程懸掛;
1.數據庫死鎖的現象程序在執行的過程中,點擊確定或保存按鈕,程序沒有響應,也沒有出現報錯。
2.死鎖的原理當對于數據庫某個表的某一列做更新或刪除等操作,執行完畢后該條語句不提交,另一條對于這一列數據做更新操作的語句在執行的...
3.死鎖的定位方法通過檢查數據庫表,能夠檢查出是哪一條語句被死鎖,產生死鎖的機器是哪一臺。 ...
4.死鎖的解決方法 一般情況下,只要將產生死鎖的語句提交就可以了,但是在實際的執行過程中.
所謂死鎖:是指兩個或兩個以上的進程在執行過程中,因爭奪資源而造成的一種互相等待的現象,若無外力作用,它們都將無法推進下去。此時稱系統處于死鎖狀態或系統產生了死鎖,這些永遠在互相等待的進程稱為死鎖進程。由于資源占用是互斥的,當某個進程提出申請資源后,使得有關進程在無外力協助下,永遠分配不到必需的資源而無法繼續運行,這就產生了一種特殊現象死鎖。雖然進程在運行過程中,可能發生死鎖,但死鎖的發生也必須具備一定的條件,死鎖的發生必須具備以下四個必要條件。1)互斥條件:指進程對所分配到的資源進行排它性使用,即在一段時間內某資源只由一個進程占用。如果此時還有其它進程請求資源,則請求者只能等待,直至占有資源的進程用畢釋放。2)請求和保持條件:指進程已經保持至少一個資源,但又提出了新的資源請求,而該資源已被其它進程占有,此時請求進程阻塞,但又對自己已獲得的其它資源保持不放。3)不剝奪條件:指進程已獲得的資源,在未使用完之前,不能被剝奪,只能在使用完時由自己釋放。4)環路等待條件:指在發生死鎖時,必然存在一個進程——資源的環形鏈,即進程集合{P0,P1,P2,···,Pn}中的P0正在等待一個P1占用的資源;P1正在等待P2占用的資源,……,Pn正在等待已被P0占用的資源。在系統中已經出現死鎖后,應該及時檢測到死鎖的發生,并采取適當的措施來解除死鎖。目前處理死鎖的方法可歸結為以下四種:1) 預防死鎖。這是一種較簡單和直觀的事先預防的方法。方法是通過設置某些限制條件,去破壞產生死鎖的四個必要條件中的一個或者幾個,來預防發生死鎖。預防死鎖是一種較易實現的方法,已被廣泛使用。但是由于所施加的限制條件往往太嚴格,可能會導致系統資源利用率和系統吞吐量降低。2) 避免死鎖。該方法同樣是屬于事先預防的策略,但它并不須事先采取各種限制措施去破壞產生死鎖的的四個必要條件,而是在資源的動態分配過程中,用某種方法去防止系統進入不安全狀態,從而避免發生死鎖。3)檢測死鎖。這種方法并不須事先采取任何限制性措施,也不必檢查系統是否已經進入不安全區,此方法允許系統在運行過程中發生死鎖。但可通過系統所設置的檢測機構,及時地檢測出死鎖的發生,并精確地確定與死鎖有關的進程和資源,然后采取適當措施,從系統中將已發生的死鎖清除掉。4)解除死鎖。這是與檢測死鎖相配套的一種措施。當檢測到系統中已發生死鎖時,須將進程從死鎖狀態中解脫出來。常用的實施方法是撤銷或掛起一些進程,以便回收一些資源,再將這些資源分配給已處于阻塞狀態的進程,使之轉為就緒狀態,以繼續運行。死鎖的檢測和解除措施,有可能使系統獲得較好的資源利用率和吞吐量,但在實現上難度也最大。
本文標題:oracle死鎖怎么造,oracle死鎖語句
文章分享:http://vcdvsql.cn/article18/hspegp.html
成都網站建設公司_創新互聯,為您提供網站收錄、企業建站、網站營銷、網站設計公司、軟件開發、電子商務
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯