zoukankan      html  css  js  c++  java
  • [Oracle]如何观察Table 的各种Lock 之间的冲突

    [Oracle]如何观察Table 的各种Lock 之间的冲突


    举例:

    Session#15 创建表:

    SID 15
    ==============
    create table t1 (c1 number)
    partition by range(c1)
    (partition p1 values less than('11'),
    partition p2 values less than('21'),
    partition p3 values less than('31')
    )
    /

    Session#15 对表给予最大限度的锁定(exclusive)

    lock table t1 in exclusive mode; (T1 X(6) lock)

    Session#137 进行其他操作(alter table add partition)

    SID 137
    ==============
    alter table t1 add partition p4 values less than ('41'); ( T1 S(4) lock, T1 X(60 无法共容,所以被阻塞,会一直停在那里)


    查看锁的状况

    SYS> select * from v$locked_object;

       XIDUSN    XIDSLOT     XIDSQN  OBJECT_ID SESSION_ID ORACLE_USERNAME                OS_USER_NAME                   PROCESS                  LOCKED_MODE
    ---------- ---------- ---------- ---------- ---------- ------------------------------ ------------------------------ ------------------------ -----------
            0          0          0      87656         15 JIMMY                          ora11204                       698                                6
            3         13       1056      87656        137 JIMMY                          ora11204                       854                                0
            3         13       1056         18        137 JIMMY                          ora11204                       854                                3


    这时我们可以执行其他操作,反正大家都被最大级别的 Exclusive 锁所阻塞,这时候就可以看看他们所执行的 lock 的 locked_mode,
    看各种操作的锁类型是否相容。

    SID#141
    ==============
    insert into t1 values(28);

    SYS> select * from v$locked_object;

       XIDUSN    XIDSLOT     XIDSQN  OBJECT_ID SESSION_ID ORACLE_USERNAME                OS_USER_NAME                   PROCESS                  LOCKED_MODE
    ---------- ---------- ---------- ---------- ---------- ------------------------------ ------------------------------ ------------------------ -----------
            6         23       1234      87659        141 JIMMY                          ora11204                       927                                3
            6         23       1234      87656        141 JIMMY                          ora11204                       927                                3
       ...

  • 相关阅读:
    常见自动化场景处理
    等待设置的三种方法
    selenium-浏览器操作
    一个 tomcat 下如何部署多个项目?附详细步骤
    Python篇:测试小白也能懂的常用加密算法解析
    如何高效开展测试用例评审?附用例评审检查清单及用例评审报告模板
    手机大厂必备测试技能-GMS 认证
    Python自动化 让接口数据秒变 python 代码
    Python自动化 谈谈 cookies
    Python自动化 作为代码小白,我是这样成为自动化大神的!
  • 原文地址:https://www.cnblogs.com/gaojian/p/7625469.html
Copyright © 2011-2022 走看看