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