博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
oracle table-lock的5种模式
阅读量:6812 次
发布时间:2019-06-26

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

Oracle中的锁定可以分为几类:DML lock(data lock),DDL lock(dictionary lock)和internal lock/latch。
DML lock又可以分为row lock和table lock。row lock在select.. for update/insert/update/delete时隐式自动产生,而table lock除了隐式产生,也可以调用lock table in name来显示锁定。

如果不希望别的session lock/insert/update/delete表中任意一行,只允许查询,可以用lock table table_name in exclusive mode。(X)这个锁定模式级别最高,并发度最小。

如果允许别的session查询或用select for update锁定记录,不允许insert/update/delete,可以用lock table table_name in share row exclusive mode。(SRX)
如 果允许别的session查询或select for update以及lock table table_name in share mode,只是不允许insert/update/delete,可以用lock table table_name in share mode。(share mode和share row exclusive mode的区别在于一个是非抢占式的而另一个是抢占式的。进入share row exclusive mode后其他session不能阻止你insert/update/delete,而进入share mode后其他session也同样可以进入share mode,进而阻止你对表的修改。(S)
还有两种锁定模式,row share(RS)和row exclusive(RX)。他们允许的并发操作更多,一般直接用DML语句自动获得,而不用lock语句。

详细参考concepts文档中的"Type Of Locks":

文章转自庄周梦蝶  ,原文发布时间5.17

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

你可能感兴趣的文章
口字型网络建立HSRP
查看>>
PostgreSQL中如何判断某个SCHEMA是否存在。
查看>>
多线多IP交换机配置(华为交换机)
查看>>
Linux平台下PHP zip模块
查看>>
写其他进程的环境变量
查看>>
Visual Studio统计有效代码行数
查看>>
Qt连接Oracle数据库常见问题
查看>>
45个实用的JavaScript技巧、窍门和最佳实践
查看>>
sqlserver 2005 列字符串拼接
查看>>
TSharding源码阅读-MapperShardingInitializer
查看>>
【01】模板模式
查看>>
在C++中,内存分成5个区
查看>>
华为SDN技术注入联通云清洗业务 从源头拒绝DDoS攻击
查看>>
python 学习day4
查看>>
ofbiz中的类加载机制classloader
查看>>
深入理解JS中的变量作用域
查看>>
go语言学习-内置函数
查看>>
vultr lemp php7.1 降级 php5.6
查看>>
《spring 4.x 企业应用开发实战》读者问题收集
查看>>
.NET英语单词 计算机英语 术语表1
查看>>