当前位置: 首页 > news >正文

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

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

相关文章:

  • 【codeforces 768F】Barrels and boxes
  • c#进阶(1)—— Task Parallel Library 并行执行与串行执行
  • UVa11374 - Airport Express(dijkstra【总是输出带来的困扰)
  • BZOJ1042: [HAOI2008]硬币购物
  • SpringBoot应用的前台目录
  • codevs 2495 水叮当的舞步
  • Maven学习(七)-----Maven添加远程仓库
  • 改变disabled背景和字体颜色
  • Django ORM OneToOneField
  • [UVALive 3716] DNA Regions
  • webSocket
  • Linux shell逐行读取文件的方法
  • 算法与数据结构3.3 calculator
  • 批处理变量详谈
  • Spring Aop 代理
  • JavaScript 如何正确处理 Unicode 编码问题!
  • [译] 怎样写一个基础的编译器
  • 5、React组件事件详解
  • ES6简单总结(搭配简单的讲解和小案例)
  • Idea+maven+scala构建包并在spark on yarn 运行
  • JavaScript函数式编程(一)
  • Node + FFmpeg 实现Canvas动画导出视频
  • PHP CLI应用的调试原理
  • Spring Boot快速入门(一):Hello Spring Boot
  • 如何利用MongoDB打造TOP榜小程序
  • 如何优雅的使用vue+Dcloud(Hbuild)开发混合app
  • 一道面试题引发的“血案”
  • 走向全栈之MongoDB的使用
  • CMake 入门1/5:基于阿里云 ECS搭建体验环境
  • Nginx实现动静分离
  • ​学习一下,什么是预包装食品?​
  • # 透过事物看本质的能力怎么培养?
  • #define与typedef区别
  • (10)STL算法之搜索(二) 二分查找
  • (2)STL算法之元素计数
  • (52)只出现一次的数字III
  • (搬运以学习)flask 上下文的实现
  • (办公)springboot配置aop处理请求.
  • (附源码)springboot社区居家养老互助服务管理平台 毕业设计 062027
  • (附源码)ssm教材管理系统 毕业设计 011229
  • (力扣记录)1448. 统计二叉树中好节点的数目
  • (六)什么是Vite——热更新时vite、webpack做了什么
  • (数位dp) 算法竞赛入门到进阶 书本题集
  • (循环依赖问题)学习spring的第九天
  • .net core webapi 大文件上传到wwwroot文件夹
  • .Net IE10 _doPostBack 未定义
  • .Net7 环境安装配置
  • .NET开发者必备的11款免费工具
  • [2024] 十大免费电脑数据恢复软件——轻松恢复电脑上已删除文件
  • [C#] 我的log4net使用手册
  • [Docker]十.Docker Swarm讲解
  • [HTML]Web前端开发技术30(HTML5、CSS3、JavaScript )JavaScript基础——喵喵画网页
  • [i.MX]飞思卡尔IMX6处理器的GPIO-IOMUX_PAD说明
  • [JavaEE系列] wait(等待) 和 notify(唤醒)
  • [Linux] 常用命令--版本信息/关机重启/目录/文件操作