oracle死結問題一直困擾著我們,下面就教您一個oracle死結的檢查方法,如果您之前遇到過oracle死結方面的問題,不妨一看……
oracle死結問題一直困擾著我們,下面就教您一個oracle死結的檢查方法,如果您之前遇到過oracle死結方面的問題,不妨一看。
一、資料庫死結的現象
程式在執行的過程中,點擊確定或儲存按鈕,程式沒有響應,也沒有出現報錯。
二、oracle死結的原理
當對於資料庫某個表的某一列做更新或刪除等操作,執行完畢後該條語句不提交,另一條對於這一列資料做更新操作的語句在執行的時候就會處於等待狀態,此時的現象是這條語句一直在執行,但一直沒有執行成功,也沒有報錯。
三、oracle死結的定位方法
通過檢查資料庫表,能夠檢查出是哪一條語句被死結,產生死結的機器是哪一台。
1)用dba使用者執行以下語句
以下是程式碼片段: select username,lockwait,status,machine,program from v$session where sid in (select session_id from v$locked_object) |
如果有輸出的結果,則說明有死結,且能看到死結的機器是哪一台。欄位說明:
Username:死結語句所用的資料庫使用者;
Lockwait:死結的狀態,如果有內容表示被死結。
Status: 狀態,active表示被死結
Machine: 死結語句所在的機器。
Program: 產生死結的語句主要來自哪個應用程式。
2)用dba使用者執行以下語句,可以查看到被死結的語句。
以下是程式碼片段: 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)) |
--本篇文章轉自: http://dev.yesky.com/450/30971950.shtml