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

Posted 健哥的数据花园

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[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
   ...

以上是关于[Oracle]如何观察Table 的各种Lock 之间的冲突的主要内容,如果未能解决你的问题,请参考以下文章

如何检查oracle数据库性能

架构师技能6:深入MySQL原理-Waiting for table metadata lock引发系统崩溃

架构师技能6:深入MySQL原理-Waiting for table metadata lock引发系统崩溃

架构师技能4:深入MySQL原理-Waiting for table metadata lock引发系统崩溃

R:如何在 data.table 中标记特定时间范围内的观察结果?

如何解决 sql 中的 lck_m_x Lock