博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
查询01_DML锁和DDL锁的处理
阅读量:6954 次
发布时间:2019-06-27

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

一、摘要


Oracle的手册上关于锁的分类说明如下:

 

1. DML锁:Date lock。执行DML时保护数据的锁。Row Lock(TX)保护特定行,Table Lock(TM)保护整个表,可以通过dba_kml_locks观察。

2. DDL锁:Data dictionary lock。保护User/Table/View/Procedure等定义,可以通过dba_ddl_locks观察。

 

实际上,DML锁和DDL锁只是为了合理分配锁而赋予的名称,请注意这点。

 

DML锁实际上与TM锁一致,DML锁可以通过dba_dml_locks视图观察,这个视图的作用是从V$lock视图上筛选出锁类型为TM的。

数据库上允许的TM锁数量,可以利用DML_LOCKS参数指定。若将DML_LOCKS参数设置为0,则对表无法获得TM锁。

这时,oracle为了保障表定义被保护,对于表根本上不允许DDL操作。

因此,即便不获得TM锁,也允许修改该表的特定行。

如OPS环境下,为了减少在全局范围内获得TM锁过程中发生的附加资源消耗,有时也将DML_LOCKS值修改为0。

 

DDL锁实际上与library cache lock 一致。

DDL锁可以通过DBA_DDL_LOCKS视图观察,这个视图世界上起到加工X$KGLLK视图后显示的作用。

DDL锁除了DBA_DDL_LOCKS视图之外,还可以通过X$KGLLK,DBA_KGLLOCK等视图观察。

对于表,普通DML语句以Sub-Exclusive(SX)模式获得TM锁。Sub-exclusive模式之间存在共享性,所以多个会话可以对形同的表执行DML。

已执行DML的会话对于表,以Sub-Exclusive莫侯斯获得TM锁,对于已修改的数据Exclusive模式获得TX锁。

 

二、监控DDL和DML锁


1. DBA_DML_LOCKS视图在v$locks视图上只选出TM锁并加工得到的;

2. DBA_DDL_LOCKS视图是加工X$KGLLK视图得到的;

Thanks and Regards

2016-03-25 Created By BaoXinjian

 

 

 

ERP技术讨论群: 288307890
技术交流,技术讨论,欢迎加入
Technology Blog Created By Oracle ERP - 鲍新建

转载地址:http://wstil.baihongyu.com/

你可能感兴趣的文章
ES6——生成器
查看>>
Friday Q&A 2015-12-11:Swift 中的弱引用
查看>>
UINavigationBar的继承与定制
查看>>
一天一点linux(8):ubuntu安装后ssh无法连接怎么解决?
查看>>
hbase_学习_00_资源帖
查看>>
【译】使用Java编写Oracle Tuxedo应用
查看>>
Oracle-07:别名,去重,子查询
查看>>
Flask從入門到入土(四)——登錄實現
查看>>
Java数字签名——DSA算法
查看>>
群体创新更能促进社会进步
查看>>
表单界面的兼容PC手机端解决方案
查看>>
恭喜"微微软"喜当爹,Github嫁入豪门。
查看>>
03.SQLServer性能优化之---存储优化系列
查看>>
如何选择和使用视频质量客观评价指标
查看>>
Hadoop源码学习之HDFS(一)
查看>>
腾讯成为 Linux 基金会白金会员,贡献两大自研项目
查看>>
有关Android插件化的一些总结思考
查看>>
队列工厂之RabbitMQ
查看>>
把图片按照指定大小剪裁,不够的地方加黑边
查看>>
02 - JavaSE之基础及面向对象(补充)
查看>>