oracle 锁的作用,oracle中锁的分类及作用

在大概了解oracle的锁机制之后,我们来解决几个基本的问题:

1.UPDATE/DELETE操作会将RS锁定,直至操作被COMMIT或者ROLLBACK;

若操作未COMMIT之前其他session对同样的RS做变更操作,则操作会被hold,直至前session的UPDATE/DELETE操作被COMMIT;

2.session内外SELECT的RS范围

前提:INSERT、UPDATE操作未COMMIT之前进行SELECT;

若在同一session内,SELECT出来的RS会包括之前INSERT、UPDATE影响的记录;

若不在同一session内,SELECT出来的RS不会包括未被COMMIT的记录;

3.SELECT.... FOR UPDATE [OF cols] [NOWAIT/WAIT] [SKIP LOCKED]

OF cols:只锁定指定字段所在表的RS,而没有指定的表则不会锁定,只会在多表联合查询时出现;

NOWAIT:语句不会hold,而是直接返回错误ORA-00054: resource busy and acquire with

NOWAIT specified;

WAIT N:语句被hold N秒,之后返回错误ORA-30006: resource busy; acquire with WAIT

timeout expired;

SKIP LOCKED:不提示错误,而是直接返回no rows selected;

以上几个选项可以联合使用的,比较推荐的有:

SELECT.... FOR UPDATE NOWAIT:对同一RS执行该SQL时,直接返回错误;

SELECT.... FOR UPDATE NOWAIT SKIP LOCKED:对同一RS执行该SQL时,直接返回空行;

PS:当RS被LOCK住之后,只对同样请求LOCK的语句有效,对无需LOCK的SELECT语句并没有任何影响;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值