1. 程式人生 > >oracle 記錄被另一個使用者鎖住 (附:操作例項)

oracle 記錄被另一個使用者鎖住 (附:操作例項)

    今天,執行Java後臺程式,設定了斷點,每到執行SQL語句時,就卡住,執行檢查,發現SQL語句並沒有問題,程式沒沒問題,於是把語句拷貝到PL/SQL裡面執行,發現還是語句執行了很久都沒有結果,於是我中斷執行,我使用的是Update語句。
    於是我就直接在上面改欄位,在點打鉤(記入改變)的時候提示,記錄被另一個使用者鎖住,一開始還以為整個表被鎖住了,後來發現,僅僅是這個欄位不能改變,其他的欄位可以。
    網上找了資料,發現是:當多個使用者併發地存取資料時,在資料庫中就會產生多個事務同時存取同一資料的情況造成的。網上也給出了答案:

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