当前位置:网站首页>Oracle数据库:for update 和for update nowait的区别
Oracle数据库:for update 和for update nowait的区别
2022-08-09 10:28:00 【jie_ming514】
for update 和for update nowait的区别
一、说明
别的事务要对这个表进行写操作时,是等待一段时间还是马上就被数据库系统拒绝而返回.制定采用nowait方式来进行检索,所以当发现数据被别的session锁定中的时候,就会迅速返回ORA-00054错误,内容是资源正忙, 但指定以 NOWAIT 方式获取资源。所以在程序中我们可以采用nowait方式迅速判断当前数据是否被锁定中,如果锁定中的话,就要采取相应的业务措施进行处理。
二、实例验证
2.1.for update nowait验证
如何理解上面的话.
- 开启一会话 (就是开一个sqlwindow)
select empno,ename from emp where empno='7369' for update nowait ;
得到下面结果集:
empno ename
7369 smith
- 开启另一会话
select empno,ename from emp where empno='7369' for update nowait ;
返回RA-00054错误,内容是资源正忙, 但指定以 NOWAIT 方式获取资源
上面会话都提交commit;
2.2.for update验证
- 开启一会话,
select empno,ename from emp where empno='7369' for update ;
得到下面结果集:
empno ename
7369 smith
- 开启另一会话
select empno,ename from emp where empno='7369' for update;
阻塞,不返回错误。
提交第一个会话,第二个回话自动执行
提交第二个会话
三、总结
3.1.for update
当第一个session最后commit或者rollback之后,第二个session中的检索结果就是自动跳出来,并且也把数据锁定住.
开启一会话:
select empno,ename from emp where empno="7369" for update;
得到下面结果集:
empno ename
7369 smith
开启另一个会话,
update emp set ename='ALLEN' where empno="7396";
阻塞。
提交第一个会话,update 语句执行
再开启一会话
update emp set ename="SMITH" where empno='7396';
同样阻塞,虽然第一个会话因为提交而释放了锁,但是第二个会话中的update 又给这一行加锁了;
3.2.for update nowait
当你第一个session放开锁定以后,第二个session才能正常运行。当你第二个session语句运行后,数据又被你第二个session语句锁定住了,这个时候只要你第二个session语句后还没有commit,别的session照样不能对数据进行锁定更新等等。
边栏推荐
猜你喜欢
机器学习--线性回归(Linear Regression)
【MySQL】mysql因为字符集导致left join出现Using join buffer (Block Nested Loop)
壁纸
想了解API接口,这一篇就够了
Demand side power load forecasting (Matlab code implementation)
BERT预训练模型(Bidirectional Encoder Representations from Transformers)-原理详解
2021-01-11-雪碧图做表情管理器
阿里神作!吃透这份资料入厂率高达99%
一天半的结果——xmms on E2
学长告诉我,大厂MySQL都是通过SSH连接的
随机推荐
对话跨国消费品牌DPO:数据安全合规从何做起?8.11直播见!
mongodb学习笔记
深度学习--生成对抗网络(Generative Adversarial Nets)
学长告诉我,大厂MySQL都是通过SSH连接的
函数组件和类组件和dva视图更新问题
好久没上博客了,好长时间没有进展了
按键精灵之输出文本
通过Doc在MySQL数据库中建表
【MySQL】mysql因为字符集导致left join出现Using join buffer (Block Nested Loop)
The GNU Privacy Guard
想了解API接口,这一篇就够了
WUSTOJ:n个素数构成等差数列
【原创】JPA中@PrePersist和@PreUpdate的用法
Qt 国际化翻译
学习NET-SNMP之一 ---------编译NET-SNMP程序。
用Word写代码
2022强网杯WP
tuple dictionary collection
The GNU Privacy Guard
如何快速打通镜像发布流程?