[转] with (nolock) 解释

select * from t1 WITH(NOLOCK) 
select * from t1 WITH(READPAST) 

 这两个都可以绕开死锁进行查询,对于允许脏读的情况特别适用。

区别是:

NOLOCK     可能把没有提交事务的数据也显示出来
READPAST 会把被锁住的行不显示出来 

但在 Oracle 中,没有类似用法

select 1 from dual for update

select 1 from dual for update nowait

Oracle 中,for update 会对行加上锁,再 for update 时会等待,而 for update nowait 时会报错:

ORA-00054 resource busy and NOWAIT specified
ORA-30006: resource busy; acquire with WAIT timeout expired
select 1 from dual FOR UPDATE SKIP LOCKED
 跳过锁,不报错不超时不等待
select 1 from dual for update wait 2

  锁 2 秒后释放锁

Oracle 部分原文:https://www.cnblogs.com/quanweiru/archive/2012/11/09/2762223.html

转载于:https://www.cnblogs.com/z5337/p/8056471.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值