博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[Oracle]如何观察Table 的各种Lock 之间的冲突
阅读量:5013 次
发布时间:2019-06-12

本文共 1454 字,大约阅读时间需要 4 分钟。

[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
   ...

转载于:https://www.cnblogs.com/gaojian/p/7625469.html

你可能感兴趣的文章
windows 中的类似于sudo的命令(在cmd中以另一个用户的身份运行命令)
查看>>
java===单类设计模式之饿汉式与懒汉式
查看>>
BZOJ 1083: [SCOI2005]繁忙的都市
查看>>
Maven 编译
查看>>
《学习之道》第十章学习方法29还记得散步的好处嘛
查看>>
Git常用命令总结
查看>>
iOS获取设备IP地址
查看>>
JavaSE| String常用方法
查看>>
NRF51822配对绑定要点
查看>>
C语言博客作业—数据类型
查看>>
[leetcode]Count and Say
查看>>
cookie、session和token的概念入门
查看>>
保护网站页面内容+版权
查看>>
Golang模拟客户端POST表单功能文件上传
查看>>
重启进程
查看>>
js 进度条效果
查看>>
RelativeLayout
查看>>
php intval()函数
查看>>
大学毕业后拉开差距的真正原因
查看>>
Java 利用SWFUpload多文件上传 session 为空失效,不能验证的问题
查看>>