Chinaunix首页 | 论坛 | 博客
  • 博客访问: 594291
  • 博文数量: 841
  • 博客积分: 5000
  • 博客等级: 大校
  • 技术积分: 5010
  • 用 户 组: 普通用户
  • 注册时间: 2008-10-28 10:08
文章分类

全部博文(841)

文章存档

2011年(1)

2008年(840)

我的朋友

分类:

2008-10-28 10:15:00

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

    环境:10201

    具体示例如下:

    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]   

【责编:Ken】

--------------------next---------------------

阅读(278) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~