zoukankan      html  css  js  c++  java
  • 为什么交易系统不能出现大事务?

    为什么Oracle要避免大事务呢?
    
    1.高并发
    
    2.回滚慢
    
    3. 从UNDO读数据也是单块读
    
    
    SQL> desc a1
     Name					   Null?    Type
     ----------------------------------------- -------- ----------------------------
     ID						    NUMBER(38)
     FLAG1						    CHAR(10)
     FLAG2						    CHAR(10)
    
    SQL> begin for i in 1 .. 1000000
      2  loop
      3  insert into a1 values (i,'a'||i,'b'||i);
      4  commit;
      5  end loop;
      6  end;
      7  /
    
    PL/SQL procedure successfully completed.
    
    SQL> delete from a1;
    
    

    全表扫描出现了单块读,因为是读的UNDO数据,查看UNDO数据:

    SQL> select s.username, u.name from v$transaction t,

    v$rollstat r, v$rollname u,v$session s 

    where s.taddr=t.addr and t.xidusn=r.

    usn and r.usn=u.usn order by s.username;  2    3    4 

     

    USERNAME             NAME

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

    TEST                 _SYSSMU3_1204390606$

     

    为什么交易系统不能出现大事务:

    SQL> set linesize 200

    SQL> select * from v$lock where sid=34;

     

    ADDR       KADDR            SID TY        ID1         ID2          LMODE    REQUEST        CTIME        BLOCK

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

    35001810 3500183C          34 AE        100          0              4           0    1752              0

    35001A54 35001A80          34 TO      65908         1              3           0    1605              0

    开始删除100W数据:

     

    SQL> select * from v$lock where sid=34;

     

    ADDR       KADDR            SID TY        ID1         ID2          LMODE    REQUEST        CTIME        BLOCK

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

    35001810 3500183C          34 AE        100          0              4           0    1772              0

    35001A54 35001A80          34 TO      65908         1              3           0    1625              0

    00707A9C 00707ACC         34 TM      75517        0              3           0       4              0

    336F4CB0 336F4CF0          34 TX     131086      12696              6           0       4              0

    删除数据时,长时间持有行锁,万一大事务失败,回滚慢,又是长时间占用行锁:

    ADDR       KADDR            SID TY        ID1         ID2          LMODE    REQUEST        CTIME        BLOCK

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

    35001810 3500183C          34 AE        100          0              4           0    1829              0

    35001A54 35001A80          34 TO      65908         1              3           0    1682              0

    00707A9C 00707ACC         34 TM      75517        0              3           0      61              0

    336F4CB0 336F4CF0          34 TX     131086      12696              6           0      61              0


     

  • 相关阅读:
    分享一个小故事
    思维局限
    java程序员笑不死的经历ส้้้้้้้้้
    一些话
    定位 java虚拟机内存问题 个人总结
    关于分布式事务、两阶段提交协议、三阶提交协议(转)
    maven常用配置信息和常量
    Mybatis-常见SQL语句示例
    Redis主从同步原理-SYNC
    B+树在mysql数据库索引中的使用
  • 原文地址:https://www.cnblogs.com/hzcya1995/p/13352430.html
Copyright © 2011-2022 走看看