SQL Server的读操作默认隔离级别
2013-11-26 14:03
225 查看
#共享锁#
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), 因为这个层级的读操作要求先加共享锁,而在有排它锁锁定该行的情况下是没法加共享锁的。当更新事务结束后排它锁被释放,该行接受读操作所请求的共享锁,读取该行,然后释放共享锁。
相关文章推荐
- sql server 隔离级别
- 【SQL Server】可重复读隔离级别里的可能死锁
- SQL Server 2005使用基于行版本控制的隔离级别初探(2) -- READ_COMMITTED_SNAPSHOT
- SQL Server 2008 R2 事务与隔离级别实例
- SQL Server的事务操作隔离模式介绍
- 数据库事务与隔离级别示例(oracle与sql server对比)
- 在连接Sql Server 2005 时,在默认的设置下SQL Server不允许远程连接可能会导致此操作
- sql server 2005使用基于行版本控制的隔离级别初探(续)
- SQL Server 之 事务与隔离级别实例讲解
- (转)mysql、sqlserver、oracle的默认事务的隔离级别
- SQL Server 2005使用基于行版本控制的隔离级别初探(3) -- SNAPSHOT
- sql server 数据库事务隔离级别
- MySQL使用可重复读作为默认隔离级别的原因
- MySQL使用可重复读作为默认隔离级别的原因之一
- 你需要明白的SQL SERVER 隔离级别
- SQL SERVER 2008 数据库隔离级别代码演示
- SQL Server 的 6 种隔离级别
- 事务操作的统计,TPS的计算,隔离级别的读提交
- SQL Server 默认跟踪应用3 -- 检测对表的DDL操作
- sql server 2005之 约束 规则 默认操作