DML操作update和delete时产生的锁示例

来源:qqread 作者:佚名 2008-04-07 出处:pcdog.com

oracle  
下一页 1 2 3 

    测试对象:在执行dml操作时都产生哪些锁,elete和update时产生的锁以及并发删除一个表时锁产生的锁。

    测试环境:Oracle10201

    具体示例如下:

    1、会话1:首先需要找到此会话的sid

    SQL> set time on

    set prompt s1

    14:46:02 s1> select sid from v$mystat where rownum<=1;

    SID

  ----------

    324

    2、会话2: 然后找到此会话的sid

    SQL> set time on

    set prompt s2

    14:46:12 s2> select sid from v$mystat where rownum<=1;

    SID

  ----------

    315

    3、会话3:查看会话1和会话2的锁情况,此时因为没有做任何dml操作所以没有锁

    SQL> set time on

    set prompt s3

    14:46:17 s3> select * from v$lock where sid in(324,315);

    ADDR KADDR SID TYPE ID1 ID2 LMODE REQUEST CTIME BLOCK

  -------- -------- ---------- ---- ---------- ---------- ---------- ---------- ---------- ----------

    4、会话1对a表删除1条数据

    14:46:35 s1> delete from a where id=2;

    1 row deleted

    5、查看此时的锁情况

    14:46:55 s3> select * from v$lock where sid in(324,315);

    ADDR KADDR SID TYPE ID1 ID2 LMODE REQUEST CTIME BLOCK

  -------- -------- ---------- ---- ---------- ---------- ---------- ---------- ---------- ----------

    81B57F70 81B57F88 324 TM 195954 0 3 0 6 0

    81C32F9C 81C330B8 324 TX 655366 308433 6 0 6 0

    6、会话2对a表执行删除操作,但不删除任何行

    14:46:44 s2> delete from a where id=3;

    0 rows deleted



下一页 1 2 3 
上一篇:Oracle10g:如何以DBA身份登陆SQL*Plus
下一篇:指定一个where条件来有条件地导出记录