• 修改2张表不同SESSION相互持有记录引发的死锁


    死锁产生的原因:如果有两个会话,每个会话都持有另一个会话想要的资源,此时就会发生死锁。
    
    2张表不同SESSION持有不同记录
    SQL> create table t1(id int);
    
    Table created.
    
    
    
    SQL> create table t2(id int);
    
    Table created.
    
    
    
    SQL> select * from t1;
    
    	ID
    ----------
    	 1
    	 2
    
    SQL> select * from t2;
    
    	ID
    ----------
    	 2
    	 1
    
    
    开始测试:
    SESSION 1:
    SQL> select * from v$mystat where rownum<2;
    
           SID STATISTIC#	   VALUE
    ---------- ---------- ----------
    	24	    0	       0
    
    
    SESSION 2:
    SQL> select * from v$mystat where rownum<2;
    
           SID STATISTIC#	   VALUE
    ---------- ---------- ----------
    	25	    0	       0
    
    SESSION 1执行:
    SQL> update t1 set id=100 where id=1;
    
    1 row updated.
    
    
    SESSION 2 执行:
    SQL> update t2 set id=100 where id=1;
    
    1 row updated.
    
    
    SESSION 1 继续执行:
    SQL> update t2 set id=100 where id=1;
    
    此时SESSION 1 HANG
    
    
    SESSION 2继续执行:
    SQL> update t1 set id=100 where id=1;
    
    
    此时SESSION 1出现:
    SQL> update t2 set id=100 where id=1;
    update t2 set id=100 where id=1
           *
    ERROR at line 1:
    ORA-00060: deadlock detected while waiting for resource
    
    --------------------------------------------------------------------
    
    SESSION 1执行:
    SQL> update t1 set id=100 where id=1;
    
    1 row updated.
    
    SQL> update t2 set id=100 where id=1;
    update t2 set id=100 where id=1
           *
    ERROR at line 1:
    ORA-00060: deadlock detected while waiting for resource
    
    
    SESSION 2 执行:
    SQL> update t2 set id=100 where id=1;
    
    1 row updated.
    
    
    SQL> update t1 set id=100 where id=1;
    
    
    
    
    查看trace日志:
    session 25:
      sid: 25 ser: 16 audsid: 1450028 user: 91/TEST flags: 0x45
      pid: 23 O/S info: user: oracle, term: UNKNOWN, ospid: 5732
        image: oracle@june (TNS V1-V3)
      client details:
        O/S info: user: oracle, term: pts/3, ospid: 5731
        machine: june program: sqlplus@june (TNS V1-V3)
        application name: SQL*Plus, hash value=3669949024
      current SQL:
      update t1 set id=100 where id=1
     
    ----- End of information for the OTHER waiting sessions -----    
     
    Information for THIS session:
     
    ----- Current SQL Statement for this session (sql_id=75ag6bf3qxyh7) -----
    update t2 set id=100 where id=1
    
    
    


     

  • 相关阅读:
    让webpack打包支持ES7的async/await语法
    你的GitHub,怎么和我用的不太一样?
    你的GitHub,怎么和我用的不太一样?
    node.js koa 实现长轮询
    node.js koa 实现长轮询
    eggjs解决跨域问题
    ElementUI表单验证攻略:解决表单项启用和禁用验证的切换,以及动态表单验证的综合性问题
    个人对内存中对象中包含对象的理解
    PAT乙级1019
    PAT乙级1036
  • 原文地址:https://www.cnblogs.com/zhaoyangjian724/p/3797935.html
Copyright © 2020-2023  润新知