oracle 記錄被另一個使用者鎖住 (附:操作例項)
阿新 • • 發佈:2019-01-28
今天,執行Java後臺程式,設定了斷點,每到執行SQL語句時,就卡住,執行檢查,發現SQL語句並沒有問題,程式沒沒問題,於是把語句拷貝到PL/SQL裡面執行,發現還是語句執行了很久都沒有結果,於是我中斷執行,我使用的是Update語句。
於是我就直接在上面改欄位,在點打鉤(記入改變)的時候提示,記錄被另一個使用者鎖住,一開始還以為整個表被鎖住了,後來發現,僅僅是這個欄位不能改變,其他的欄位可以。
網上找了資料,發現是:當多個使用者併發地存取資料時,在資料庫中就會產生多個事務同時存取同一資料的情況造成的。網上也給出了答案:
1、檢視資料庫鎖,診斷鎖的來源及型別:
2、找出資料庫的serial#,以備殺死:
3、殺死該session
用步驟2中查出來的記錄,對應進該語句刪除
就是這樣子,以下是我操作的方法:
第一步:(只是用於檢視哪些表被鎖住,真正有用的是第二、第三步)
OWNER OBJECT_NAME SESSION_ID LOCKED_MODE
1 BSZCGL TDISPOSE_ACCEPT_F 1115 3
2 BSZCGL TDISPOSE_ACCEPT_F 1097 3
3 BSZCGL TDISPOSE_ACCEPT_Z 1116 3
4 BSZCGL TDISPOSE_ACCEPT_Z 1111 3
5 BSZCGL TDISPOSE_ACCEPT_Z 1103 3
6 BSZCGL TDISPOSE_ACCEPT_Z 1100 3
7 BSZCGL TDISPOSE_ACCEPT_Z 1097 3
8 BSZCGL TDISPOSE_ACCEPT_Z 1092 3
9 BSZCGL TDISPOSE_DAMAGE_Z 1106 3
10 BSZCGL TZC6_22CL 1097 3
可以看出,那些表被鎖住
第二步:
USERNAME SID SERIAL# LOGON_TIME
1 BSZCGL 1115 132 2011-12-6 14:51:35
2 BSZCGL 1097 116 2011-12-6 14:51:57
3 BSZCGL 1097 116 2011-12-6 14:51:57
4 BSZCGL 1097 116 2011-12-6 14:51:57
5 BSZCGL 1111 155 2011-12-6 14:56:29
6 BSZCGL 1103 292 2011-12-6 14:57:34
7 BSZCGL 1116 388 2011-12-6 15:04:56
8 BSZCGL 1100 240 2011-12-6 15:08:13
9 BSZCGL 1106 228 2011-12-6 15:26:20
10 BSZCGL 1092 10 2011-12-6 15:26:46
第三步:(關鍵)
執行:(alter system kill session 'sid,serial#')具體如下:
有可能執行完一條之後,其他的ID也跟著消失,執行完3後,在執行2,檢查時候清除完畢
於是我就直接在上面改欄位,在點打鉤(記入改變)的時候提示,記錄被另一個使用者鎖住,一開始還以為整個表被鎖住了,後來發現,僅僅是這個欄位不能改變,其他的欄位可以。
網上找了資料,發現是:當多個使用者併發地存取資料時,在資料庫中就會產生多個事務同時存取同一資料的情況造成的。網上也給出了答案:
1、檢視資料庫鎖,診斷鎖的來源及型別:
或者用以下命令:select object_id,session_id,locked_mode from v$locked_object;
select b.owner,b.object_name,l.session_id,l.locked_mode
from v$locked_object l, dba_objects b
where b.object_id=l.object_id
SELECT lpad(' ',decode(l.xidusn ,0,3,0))||l.oracle_username User_name, o.owner,o.object_name,o.object_type,s.sid,s.serial# FROM v$locked_object l,dba_objects o,v$session s WHERE l.object_id=o.object_id AND l.session_id=s.sid ORDER BY o.object_id,xidusn DESC
2、找出資料庫的serial#,以備殺死:
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;
3、殺死該session
alter system kill session 'sid,serial#'
用步驟2中查出來的記錄,對應進該語句刪除
就是這樣子,以下是我操作的方法:
第一步:(只是用於檢視哪些表被鎖住,真正有用的是第二、第三步)
後:select b.owner,b.object_name,l.session_id,l.locked_mode from v$locked_object l, dba_objects b where b.object_id=l.object_id
OWNER OBJECT_NAME SESSION_ID LOCKED_MODE
1 BSZCGL TDISPOSE_ACCEPT_F 1115 3
2 BSZCGL TDISPOSE_ACCEPT_F 1097 3
3 BSZCGL TDISPOSE_ACCEPT_Z 1116 3
4 BSZCGL TDISPOSE_ACCEPT_Z 1111 3
5 BSZCGL TDISPOSE_ACCEPT_Z 1103 3
6 BSZCGL TDISPOSE_ACCEPT_Z 1100 3
7 BSZCGL TDISPOSE_ACCEPT_Z 1097 3
8 BSZCGL TDISPOSE_ACCEPT_Z 1092 3
9 BSZCGL TDISPOSE_DAMAGE_Z 1106 3
10 BSZCGL TZC6_22CL 1097 3
可以看出,那些表被鎖住
第二步:
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;
後:USERNAME SID SERIAL# LOGON_TIME
1 BSZCGL 1115 132 2011-12-6 14:51:35
2 BSZCGL 1097 116 2011-12-6 14:51:57
3 BSZCGL 1097 116 2011-12-6 14:51:57
4 BSZCGL 1097 116 2011-12-6 14:51:57
5 BSZCGL 1111 155 2011-12-6 14:56:29
6 BSZCGL 1103 292 2011-12-6 14:57:34
7 BSZCGL 1116 388 2011-12-6 15:04:56
8 BSZCGL 1100 240 2011-12-6 15:08:13
9 BSZCGL 1106 228 2011-12-6 15:26:20
10 BSZCGL 1092 10 2011-12-6 15:26:46
第三步:(關鍵)
執行:(alter system kill session 'sid,serial#')具體如下:
alter system kill session '1115,132'
alter system kill session '1097,116'
alter system kill session '1111,155'
alter system kill session '1103,292'
alter system kill session '1116,388'
alter system kill session '1100,240'
alter system kill session '1106,228'
alter system kill session '1092,10'
執行成功,會提示執行完畢!有可能執行完一條之後,其他的ID也跟著消失,執行完3後,在執行2,檢查時候清除完畢
轉載自:http://blog.sina.com.cn/s/blog_613963d10100ymj8.html