SQL Server的读操作默认隔离级别

#共享锁# 
1、共享 (S) 锁允许并发事务读取 (SELECT) 一个资源。
2、资源上存在共享 (S) 锁时,任何其它事务都不能修改数据。
3、一旦已经读取数据,便立即释放资源上的共享 (S) 锁,除非将事务隔离级别设置为可重复读或更高级别,或者在事务生存周期内用锁定提示保留共享 (S) 锁。 

#WITH(NOLOK)#
不对读取资源施加共享锁(S),不会阻止其他的写操作。

#SQL Server默认隔离级别#
防止读到脏数据的的最低隔离层级就是READ COMMITTED ,它也是所有版本的Sql  Server读操作时的默认隔离层级.顾名思义,这个层级只允许读取已经提交过的数据。
这就是说如果更新一行的事务还没有结束时试图读取该行的操作将被Block(只能等待更新事务结束unblock), 因为这个层级的读操作要求先加共享锁,而在有排它锁锁定该行的情况下是没法加共享锁的。当更新事务结束后排它锁被释放,该行接受读操作所请求的共享锁,读取该行,然后释放共享锁。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值