博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Oracle--加锁的方法
阅读量:2443 次
发布时间:2019-05-10

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

行共享锁(Row Share ,RS)

对数据表定义了行共享锁后,如果被事务A获得,那么其他事务可以进行并发查询、插入、删除及加锁,但不能以排他方式存取该数据表。

为Student表添加行共享锁

在这里插入图片描述

行排他锁(Row Exclusive,RX)

当事务A获得行排他锁后,其他事务可以对同一数据表中的其他数据行进行并发查询、插入、修改、删除及加锁,但不能使用行共享锁、行共享排他锁和行排他锁3种方式加锁。

为Student表添加行排他锁

在这里插入图片描述

共享锁(Share,S)

当事务A获得共享锁后,其他事务可以对同一数据表中的其他数据行进行并发查询、加共享锁但不能修改表,不能使用排他锁、行共享排他锁和行排他锁3种方式加锁。

为Student表添加共享锁

第一步:为表Student添加排他锁

在这里插入图片描述

第二步:打开一个新的SQL Plus会话,分别执行查询和更新操作

在这里插入图片描述

此时,新打开的会话可以查询,但是更新语句一直处于锁等待的状态。回到第一个会话,当解除锁,例如输入rollback回滚操作后,新会话会立刻执行完成。

在这里插入图片描述

共享行排他锁(Share Row Exclusive,SRX)

当事务A获得共享排他锁后,其他事务可以执行查询和对其他数据行加锁,但不能修改表,也不能再添加共享锁、共享行排他锁、行排他锁和排他锁。

为Student添加共享行排他锁

第一步:为Student添加共享行排他锁

在这里插入图片描述

第二步:新会话中为student添加共享锁

在这里插入图片描述
发现,新打开的会话窗口,为已经添加共享排他锁的事务再次添加共享锁时,一直处于等待状态,当第一个会话释放资源时,第二个会话方可执行。
在这里插入图片描述

排他锁(Exclusive,X)

排他锁是最严格的锁,当事务A获得排他锁后,事务A可以执行对数据表的读写操作,其他事务可以执行查询但不能执行插入、修改和删除操作。

其他事务可以执行查询和对其他数据行加锁,但不能修改表,也不能再添加共享锁、共享行排他锁,行排他锁和排他锁。

为Student表添加排他锁

第一步:为表Student添加排他锁

在这里插入图片描述

第二步:打开一个新的SQL Plus会话,分别执行查询和更新操作

在这里插入图片描述
此时,新打开的会话可以查询,但是更新语句一直处于锁等待状态。回到第一个会话,解除锁,新会话立刻执行完成。
在这里插入图片描述

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

你可能感兴趣的文章
使用PHP从Access数据库中提取对象,第2部分
查看>>
openbiz_Openbiz Cubi:健壮PHP应用程序框架,第1部分
查看>>
使用PHP从Access数据库中提取对象,第1部分
查看>>
使用云waf的案例_9种流行的云使用案例
查看>>
类集合转换类集合_PHP中的集合类
查看>>
使用SimplePie消费Feed
查看>>
运算符二进制_基本转换和二进制运算符
查看>>
SitePoint播客#121:在线社区圆桌会议第2部分
查看>>
pchart_用pChart绘制图表
查看>>
Git简介,第1部分
查看>>
微信 获取地理位置名称_使用地理名称的目标地理位置
查看>>
graph api_与Facebook Graph API集成
查看>>
本地应用程序_本地化PHP应用程序的“正确方法”,第4部分
查看>>
mfc单文档绘制世界坐标系_文档使世界运转
查看>>
防止跨站请求伪造(CSRF)
查看>>
科创板 云计算业务公司_云计算对您的业务意味着什么
查看>>
SitePoint播客#80:与澳大利亚团队的FullCodePress
查看>>
BigCommerce和Volusion:比较设置和移动
查看>>
使用codeigniter_使用CodeIgniter探索面向方面的编程,第2部分
查看>>
用Wufoo创建简单表单:开发人员的观点
查看>>