#共享锁#
1、共享 (S) 锁允许并发事务读取 (SELECT) 一个资源。
2、资源上存在共享 (S) 锁时,任何其它事务都不能修改数据。
3、一旦已经读取数据,便立即释放资源上的共享 (S) 锁,除非将事务隔离级别设置为可重复读或更高级别,或者在事务生存周期内用锁定提示保留共享 (S) 锁。
#WITH(NOLOK)#
不对读取资源施加共享锁(S),不会阻止其他的写操作。
#SQL Server默认隔离级别#
防止读到脏数据的的最低隔离层级就是READ COMMITTED ,它也是所有版本的Sql Server读操作时的默认隔离层级.顾名思义,这个层级只允许读取已经提交过的数据。
这就是说如果更新一行的事务还没有结束时试图读取该行的操作将被Block(只能等待更新事务结束unblock), 因为这个层级的读操作要求先加共享锁,而在有排它锁锁定该行的情况下是没法加共享锁的。当更新事务结束后排它锁被释放,该行接受读操作所请求的共享锁,读取该行,然后释放共享锁。
1、共享 (S) 锁允许并发事务读取 (SELECT) 一个资源。
2、资源上存在共享 (S) 锁时,任何其它事务都不能修改数据。
3、一旦已经读取数据,便立即释放资源上的共享 (S) 锁,除非将事务隔离级别设置为可重复读或更高级别,或者在事务生存周期内用锁定提示保留共享 (S) 锁。
#WITH(NOLOK)#
不对读取资源施加共享锁(S),不会阻止其他的写操作。
#SQL Server默认隔离级别#
防止读到脏数据的的最低隔离层级就是READ COMMITTED ,它也是所有版本的Sql Server读操作时的默认隔离层级.顾名思义,这个层级只允许读取已经提交过的数据。
这就是说如果更新一行的事务还没有结束时试图读取该行的操作将被Block(只能等待更新事务结束unblock), 因为这个层级的读操作要求先加共享锁,而在有排它锁锁定该行的情况下是没法加共享锁的。当更新事务结束后排它锁被释放,该行接受读操作所请求的共享锁,读取该行,然后释放共享锁。