ITPub博客

首页 > 数据库 > Oracle > 关于外键未加索引引起锁问题

关于外键未加索引引起锁问题

原创 Oracle 作者:yaanzy 时间:2008-06-25 20:07:32 0 删除 编辑

测试:

session 1:

SQL> delete from emp where emp.deptno=10;

session 2:

SQL> delete from dept where deptno=40;

现象:在emp的字段deptno没有索引时session 2等待, 有索引则不等待.

结论:如果没有索引时,对父表的操作,会级联加一个TM S锁(level 4)到子表上;
如果有索引时,对父表的操作,会级联加一个TM RS锁(level 2)到子表上;
这时如果子表上本身就有个TM RX锁(这种锁很容易产生,insert update delete都会产生这种锁),
TM S锁和TM RX锁是互斥的, TM RS锁和TM RX锁是相容的.

[@more@]

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/3898/viewspace-1006128/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论
  • 博文量
    108
  • 访问量
    766258