ORACLE DML語句鎖機制導致事務等待示例
UPDATE產生鎖示例
session 1:
SQL> conn dayonger/dayonger;
Connected.
SQL> create table test(id number primary key,name varchar2(10)); --建立測試表
Table created.
session 1:
SQL> conn dayonger/dayonger;
Connected.
SQL> create table test(id number primary key,name varchar2(10)); --建立測試表
Table created.
SQL> conn / as sysdba
Connected.
SQL> select sid from v$mystat where rownum=1;
SID
----------
131
Connected.
SQL> select sid from v$mystat where rownum=1;
SID
----------
131
SQL> conn dayonger/dayonger;
Connected.
SQL> insert into test values(1,'dayonger'); --插入測試資料
1 row created.
SQL> insert into test values(2,'xiaoru');
1 row created.
SQL> commit;
Commit complete.
SQL> update test set name='eryonger' where id=2; --update修改一行資料,不提交該事務
1 row updated.
Connected.
SQL> insert into test values(1,'dayonger'); --插入測試資料
1 row created.
SQL> insert into test values(2,'xiaoru');
1 row created.
SQL> commit;
Commit complete.
SQL> update test set name='eryonger' where id=2; --update修改一行資料,不提交該事務
1 row updated.
session 2:
SQL> select sid from v$mystat where rownum=1;
SID
----------
147
SQL> update dayonger.test set name='madaha' where id=2; --由於session 1對該行資料修改未結束,該事務將等待
session 3:
SQL> select sid from v$mystat where rownum=1;
SID
----------
148
SQL> select sid,type,id1,id2,lmode,request,block from v$lock where sid in (131,147) order by 1,2;
SID TY ID1 ID2 LMODE REQUEST BLOCK
---------- -- ---------- ---------- ---------- ---------- ----------
131 TM 52647 0 3 0 2
131 TX 65580 410 6 0 1
147 TM 52647 0 3 0 2
147 TX 65580 410 0 6 0
SQL> select sid from v$mystat where rownum=1;
SID
----------
147
SQL> update dayonger.test set name='madaha' where id=2; --由於session 1對該行資料修改未結束,該事務將等待
session 3:
SQL> select sid from v$mystat where rownum=1;
SID
----------
148
SQL> select sid,type,id1,id2,lmode,request,block from v$lock where sid in (131,147) order by 1,2;
SID TY ID1 ID2 LMODE REQUEST BLOCK
---------- -- ---------- ---------- ---------- ---------- ----------
131 TM 52647 0 3 0 2
131 TX 65580 410 6 0 1
147 TM 52647 0 3 0 2
147 TX 65580 410 0 6 0
SQL> select sid,event from v$session_wait where sid in (131,147);
SID EVENT
---------- ----------------------------------------------------------------
131 SQL*Net message from client
147 enq: TX - row lock contention
SID EVENT
---------- ----------------------------------------------------------------
131 SQL*Net message from client
147 enq: TX - row lock contention
批註:
v$lock的lmode和request相應數值的含義是:
TM是一個表級鎖(段鎖),表示此表的記錄在修改時,不允許對錶進行DDL操作;
TX是一個行級鎖(事務鎖),表示不允許對錶修改的記錄進行DML操作;
v$lock的lmode和request相應數值的含義是:
TM是一個表級鎖(段鎖),表示此表的記錄在修改時,不允許對錶進行DDL操作;
TX是一個行級鎖(事務鎖),表示不允許對錶修改的記錄進行DML操作;
當TY=TM and ID2=0時,ID1的值為此表(段)的object_id;
當TY=TX and ID2<>0時,ID1+ID2構成了這個事務在回滾段中的位置;
LMODE=3表示一個行級排它鎖,LMODE=6表級的排他鎖;
REQUEST=6 表示當前會話正待等待一個LMODE=6 的鎖,表明這個會話正在被阻塞;
block=1是表示這個會話正在阻塞其它會話;
DELETE產生鎖示例
session1:
SQL>set sqlprompt '&window>'
Enter value for window: session1
session1>select sid from v$mystat where rownum=1;
SID
----------
148
session1>select * from dayonger.test;
ID NAME
---------- ----------
1 dayonger
2 xiaoru
session1>delete from dayonger.test where id=2; --執行delete,該語句不提交
1 row deleted.
當TY=TX and ID2<>0時,ID1+ID2構成了這個事務在回滾段中的位置;
LMODE=3表示一個行級排它鎖,LMODE=6表級的排他鎖;
REQUEST=6 表示當前會話正待等待一個LMODE=6 的鎖,表明這個會話正在被阻塞;
block=1是表示這個會話正在阻塞其它會話;
DELETE產生鎖示例
session1:
SQL>set sqlprompt '&window>'
Enter value for window: session1
session1>select sid from v$mystat where rownum=1;
SID
----------
148
session1>select * from dayonger.test;
ID NAME
---------- ----------
1 dayonger
2 xiaoru
session1>delete from dayonger.test where id=2; --執行delete,該語句不提交
1 row deleted.
session2:
session2>select sid from v$mystat where rownum=1;
SID
----------
131
SQL> set sqlprompt '&window>'
Enter value for window: session2
session2>delete from dayonger.test where id=2; --此時刪除同行資料時產生等待
session3:
session3>select sid,type,id1,id2,lmode,request,block from v$lock
2 where sid in(131,148) order by 1,2;
SID TY ID1 ID2 LMODE REQUEST BLOCK
---------- -- ---------- ---------- ---------- ---------- ----------
131 TM 52647 0 3 0 2
131 TX 393249 411 0 6 0
148 TM 52647 0 3 0 2
148 TX 393249 411 6 0 1
session2>select sid from v$mystat where rownum=1;
SID
----------
131
SQL> set sqlprompt '&window>'
Enter value for window: session2
session2>delete from dayonger.test where id=2; --此時刪除同行資料時產生等待
session3:
session3>select sid,type,id1,id2,lmode,request,block from v$lock
2 where sid in(131,148) order by 1,2;
SID TY ID1 ID2 LMODE REQUEST BLOCK
---------- -- ---------- ---------- ---------- ---------- ----------
131 TM 52647 0 3 0 2
131 TX 393249 411 0 6 0
148 TM 52647 0 3 0 2
148 TX 393249 411 6 0 1
session3>select sid,event from v$session_wait where sid in(131,148);
SID EVENT
---------- ----------------------------------------------------------------
131 enq: TX - row lock contention
148 SQL*Net message from client
session1:
session1>select sid from v$mystat where rownum=1;
SID
----------
148
session1>insert into dayonger.test values (3,'demaxiya'); --插入資料不提交
1 row created.
SID EVENT
---------- ----------------------------------------------------------------
131 enq: TX - row lock contention
148 SQL*Net message from client
批註:
TM是一個表級鎖(段鎖),表示此表的記錄在修改時,不允許對錶進行DDL操作;
TX是一個行級鎖(事務鎖),表示不允許對錶修改的記錄進行DML操作;
當TY=TM and ID2=0時,ID1的值為此表(段)的object_id;
當TY=TX and ID2<>0時,ID1+ID2構成了這個事務在回滾段中的位置;
LMODE=3表示一個行級排它鎖,LMODE=6表級的排他鎖;
REQUEST=6 表示當前會話正待等待一個LMODE=6 的鎖,表明這個會話正在被阻塞;
block=1是表示這個會話正在阻塞其它會話;
INSERT產生鎖示例TM是一個表級鎖(段鎖),表示此表的記錄在修改時,不允許對錶進行DDL操作;
TX是一個行級鎖(事務鎖),表示不允許對錶修改的記錄進行DML操作;
當TY=TM and ID2=0時,ID1的值為此表(段)的object_id;
當TY=TX and ID2<>0時,ID1+ID2構成了這個事務在回滾段中的位置;
LMODE=3表示一個行級排它鎖,LMODE=6表級的排他鎖;
REQUEST=6 表示當前會話正待等待一個LMODE=6 的鎖,表明這個會話正在被阻塞;
block=1是表示這個會話正在阻塞其它會話;
session1:
session1>select sid from v$mystat where rownum=1;
SID
----------
148
session1>insert into dayonger.test values (3,'demaxiya'); --插入資料不提交
1 row created.
session2:
session1>select sid from v$mystat where rownum=1;
SID
----------
131
session2>insert into dayonger.test values (3,'sameID'); --插入相同的ID號,該表中ID為主鍵,事務將等待
session3:
session3>select sid,type,id1,id2,lmode,request,block from v$lock
2 where sid in(131,148) order by 1,2;
SID TY ID1 ID2 LMODE REQUEST BLOCK
---------- -- ---------- ---------- ---------- ---------- ----------
131 TM 52647 0 3 0 2
131 TX 655390 424 6 0 2
131 TX 589846 428 0 4 0
148 TM 52647 0 3 0 2
148 TX 589846 428 6 0 1
session3>select sid,event from v$session_wait where sid in(131,148);
SID EVENT
---------- ----------------------------------------------------------------
131 enq: TX - row lock contention
148 SQL*Net message from client
session1:
session1>select sid from v$mystat where rownum=1;
SID
----------
148
session1>select * from dayonger.test for update;
ID NAME
---------- ----------
3 demaxiya
1 dayonger
2 xiaoru
session1>select sid from v$mystat where rownum=1;
SID
----------
131
session2>insert into dayonger.test values (3,'sameID'); --插入相同的ID號,該表中ID為主鍵,事務將等待
session3:
session3>select sid,type,id1,id2,lmode,request,block from v$lock
2 where sid in(131,148) order by 1,2;
SID TY ID1 ID2 LMODE REQUEST BLOCK
---------- -- ---------- ---------- ---------- ---------- ----------
131 TM 52647 0 3 0 2
131 TX 655390 424 6 0 2
131 TX 589846 428 0 4 0
148 TM 52647 0 3 0 2
148 TX 589846 428 6 0 1
session3>select sid,event from v$session_wait where sid in(131,148);
SID EVENT
---------- ----------------------------------------------------------------
131 enq: TX - row lock contention
148 SQL*Net message from client
批註:
這裡和update產生鎖的情況不一樣的是,session2在持有一個LMODE=6的排他鎖和等待一個LMODE=4的鎖。
因插入的並不是同一條記錄,session2插入時的記錄沒被阻塞,而是對錶的資料塊頭修改的阻塞,所以會話在請求一個LMODE=4的鎖。
SELECT ... FOR UPDATE產生鎖示例這裡和update產生鎖的情況不一樣的是,session2在持有一個LMODE=6的排他鎖和等待一個LMODE=4的鎖。
因插入的並不是同一條記錄,session2插入時的記錄沒被阻塞,而是對錶的資料塊頭修改的阻塞,所以會話在請求一個LMODE=4的鎖。
session1:
session1>select sid from v$mystat where rownum=1;
SID
----------
148
session1>select * from dayonger.test for update;
ID NAME
---------- ----------
3 demaxiya
1 dayonger
2 xiaoru
session2:
session2>select * from dayonger.test;
ID NAME
---------- ----------
3 demaxiya
1 dayonger
2 xiaoru
session2>update dayonger.test set name='douzhanshenghuo' where id=3;
session3:
session3>select sid,type,id1,id2,lmode,request,block from v$lock
2 where sid in(131,148) order by 1,2;
SID TY ID1 ID2 LMODE REQUEST BLOCK
---------- -- ---------- ---------- ---------- ---------- ----------
131 TM 52647 0 3 0 2
131 TX 393236 412 0 6 0
148 TM 52647 0 3 0 2
148 TX 393236 412 6 0 1
session3>select sid,event from v$session_wait where sid in(131,148);
SID EVENT
---------- ----------------------------------------------------------------
131 enq: TX - row lock contention
148 SQL*Net message from client
補充:可以使用如下語句殺掉導致等待事件的會話
session3>alter system kill session '148,131';
System altered.
session3>select sid,type,id1,id2,lmode,request,block from v$lock
2 where sid in(131,148) order by 1,2;
no rows selected
session2>select * from dayonger.test;
ID NAME
---------- ----------
3 demaxiya
1 dayonger
2 xiaoru
session2>update dayonger.test set name='douzhanshenghuo' where id=3;
session3:
session3>select sid,type,id1,id2,lmode,request,block from v$lock
2 where sid in(131,148) order by 1,2;
SID TY ID1 ID2 LMODE REQUEST BLOCK
---------- -- ---------- ---------- ---------- ---------- ----------
131 TM 52647 0 3 0 2
131 TX 393236 412 0 6 0
148 TM 52647 0 3 0 2
148 TX 393236 412 6 0 1
session3>select sid,event from v$session_wait where sid in(131,148);
SID EVENT
---------- ----------------------------------------------------------------
131 enq: TX - row lock contention
148 SQL*Net message from client
補充:可以使用如下語句殺掉導致等待事件的會話
session3>alter system kill session '148,131';
System altered.
session3>select sid,type,id1,id2,lmode,request,block from v$lock
2 where sid in(131,148) order by 1,2;
no rows selected
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29634949/viewspace-1277294/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- ORACLE 資料庫 查詢語句與DML語句Oracle資料庫
- Postgrsql 從節點當機,主節點執行DML語句出現等待情況SQL
- 入門MySQL——DML語句篇MySql
- MySQL基礎之DML語句MySql
- 6.3. 基本SQL語句——6.3.2. DMLSQL
- MySQL 的資料管理及 DML 語句MySql
- Oracle:select 或 inactive 會話語句產生鎖?Oracle會話
- Java多執行緒之三volatile與等待通知機制示例Java執行緒
- 寫一個“特殊”的查詢構造器 – (七、DML 語句、事務)
- ORACLE常用語句:Oracle
- oracle資料庫檢視鎖表的sql語句整理Oracle資料庫SQL
- Shell階段04 shell流程之case語句, 服務啟動停止指令碼(rsync, nginx), shell加鎖機制指令碼Nginx
- Oracle多粒度封鎖機制研究二(zt)Oracle
- redis(10)事務和鎖機制Redis
- mysql 事務,鎖,隔離機制MySql
- Oracle Parallel DMLOracleParallel
- Oracle基本SQL語句OracleSQL
- Oracle 建立序列語句Oracle
- 【解決DML 語句包含不帶 INTO 子句的 OUTPUT 子句】
- mysql事務處理與鎖機制MySql
- SQL查詢語句 (Oracle)SQLOracle
- MySQL中的事務原理和鎖機制MySql
- GaussDB SQL基礎語法示例-迴圈語句SQL
- MySQL教程DML資料操縱語言示例詳解鍵塾MySql
- PHP 鎖機制PHP
- SQLite鎖機制SQLite
- Oracle死鎖一例(ORA-00060),鎖表導致的業務死鎖問題Oracle
- Java併發之等待/通知機制Java
- ORACLE多表關聯UPDATE語句Oracle
- oracle中的條件語句Oracle
- Oracle資料庫語句大全Oracle資料庫
- 列出oracle dbtime得sql語句OracleSQL
- oracle檢視物件DDL語句Oracle物件
- 【LOB】Oracle lob管理常用語句Oracle
- oracle語句練習--初級Oracle
- oracle資料庫常用語句Oracle資料庫
- Mysql事務隔離級別與鎖機制MySql
- MySQL 死鎖和鎖等待MySql
- 強制等待