1. 程式人生 > 資料庫 >Oracle報錯記錄被另外一個使用者鎖定的解決方案

Oracle報錯記錄被另外一個使用者鎖定的解決方案

原因

當一個使用者對資料進行修改時,若沒有進行提交或者回滾,Oracle不允許其他使用者修改該條資料,在這種情況下修改,就會出現:“記錄被另外一個使用者鎖定”錯誤。

解決

查詢使用者、資料庫鎖、以及型別等

select object_id,session_id,locked_mode from v$locked_object;

或者

select t2.owner,t2.object_name,t1.session_id,t1.locked_mode
from v$locked_object t1,dba_objects t2
where t2.object_id=t1.object_id

結果如下:(使用者:HRXT;操作表:HRSA_RESERVES_STAFF;鎖編號:1026;鎖型別:3)

Oracle報錯記錄被另外一個使用者鎖定的解決方案

查詢對應的serial和sid,用來kill掉會話程序

select t2.username,t2.sid,t2.serial#,t2.logon_time
from v$locked_object t1,v$session t2
where t1.session_id=t2.sid order by t2.logon_time;

結果如:

Oracle報錯記錄被另外一個使用者鎖定的解決方案

kill掉該會話程序

alter system kill session 'sid,serial#'

本案例中kill程序語句為:

alter system kill session '1026,14490'

到這裡,就可以解決“記錄被另外一個使用者鎖定”錯誤,如果出現如下圖錯誤:

Oracle報錯記錄被另外一個使用者鎖定的解決方案

說明你的許可權不足,請用管理員賬號登入資料庫再重新1,2,3步驟,或者聯絡資料庫管理員賦予你相關許可權。

總結

到此這篇關於Oracle報錯記錄被另外一個使用者鎖定的解決方案的文章就介紹到這了,更多相關Oracle報錯使用者鎖定內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!