锁模式---SQLServer008R2

来源:互联网 发布:重庆文理学院教务网络 编辑:程序博客网 时间:2024/06/06 08:35
  

所模式

说明

共享(s)

用于不更改或者不更新数据的读取模式如SELECT语句

更新(U)

用于可更新的资源中。防止多个会话在读取、锁定以及随后可能进行的资源更新时发生常见形式的死锁。

排他(X)

用于数据修改操作,如INSERT、UPDATE、或DELETE。确保不会同时对统一资源进行多重更新

意向

用于简历锁的层次结构。意向锁包含三种类型:意向共享(IS)、意向排他(IX)和意向排他共享(SIX)

架构

在执行依赖于表家架构的操作使用。架构在锁包含两种类型:架构修改(Sch-M)和架构稳定性(Sch-S)。

大容量更新

在想表进行大容量数据复制且指定了TABLOCK提示时使用

键范围

当使用可序列化事务隔离级别时保护查询读取的行为的范围。确保再次运行查询时其他事务无法插入符合可序列化事务查询的行

 

共享锁

        共享锁(s)允许并发事务在封闭式并发控制下读取(SELECT)资源。资源上存在共享锁(s锁)时,任何其他的事务都不能修改数据。读取操作已完成,就立即释放资源上的共享锁(s锁),除非将事务隔离级别的设置为可重复读或者更高级别,或者在十五持续时间内用所提示保留共享锁(s锁)

更新锁

       更新锁(U锁)可以防止常见的死锁。在可重复读或者可序列化的事务中,此事务读取数据【获取资源(页或行)的共享锁(s锁)】,然后修改数据【次操作要求所转换为排他锁(x)】。如果两个事务获得了资源上的共享模式锁,然后试图进行更新数据,则一个事务尝试将锁转换为排他锁(x锁)。共享模式到排他锁的转换必须等待一段时间,因为一个事务的排他锁与其他事务的共享模式锁不兼容;发生锁等待。第二个事务试图获取排他锁(X锁)以进行更行新。由于两个事务都要转换为排他锁(x锁),并且每个事务都等待另一个事务释放共享模式锁,因此发生死锁。

排他锁

      排他锁(x锁)可以防止并发事务对资源进行访问。使用排他锁(x锁)时,任何其他事务都无法修改数据;仅在使用NOLOCK提示或未提交读隔离级别时才进行读取操作。

      数据修改语句(如INSERT、UPDATE、和DELETE)合并了修改和读取操作。语句执行所需的修改操作之前首先执行行读取操作以获取数据。因此,数据修改语句通常请求共享锁和排他锁。例如UPDATE语可能根据与一个表的连接修改另一个表中的行。在如此情况下,除了请求更新行上的的排他锁之外,UPDATE语句还将请求在连接表中读取行上的共享锁。

意向锁

      

数据库引擎使用意向锁来保护共享锁(S 锁)或排他锁(X 锁)放置在锁层次结构的底层资源上。 意向锁之所以命名为意向锁,是因为在较低级别锁前可获取它们,因此会通知意向将锁放置在较低级别上。

意向锁有两种用途:

  • 防止其他事务以会使较低级别的锁无效的方式修改较高级别资源。

  • 提高数据库引擎在较高的粒度级别检测锁冲突的效率。

例如,在该表的页或行上请求共享锁(S 锁)之前,在表级请求共享意向锁。 在表级设置意向锁可防止另一个事务随后在包含那一页的表上获取排他锁(X 锁)。 意向锁可以提高性能,因为数据库引擎仅在表级检查意向锁来确定事务是否可以安全地获取该表上的锁。 而不需要检查表中的每行或每页上的锁以确定事务是否可以锁定整个表。

意向锁包括意向共享 (IS)、意向排他 (IX) 以及意向排他共享 (SIX)。

锁模式

说明

意向共享 (IS)

保护针对层次结构中某些(而并非所有)低层资源请求或获取的共享锁。

意向排他 (IX)

保护针对层次结构中某些(而并非所有)低层资源请求或获取的排他锁。 IX 是 IS 的超集,它也保护针对低层级别资源请求的共享锁。

意向排他共享 (SIX)

保护针对层次结构中某些(而并非所有)低层资源请求或获取的共享锁以及针对某些(而并非所有)低层资源请求或获取的意向排他锁。 顶级资源允许使用并发 IS 锁。 例如,获取表上的 SIX 锁也将获取正在修改的页上的意向排他锁以及修改的行上的排他锁。 虽然每个资源在一段时间内只能有一个 SIX 锁,以防止其他事务对资源进行更新,但是其他事务可以通过获取表级的 IS 锁来读取层次结构中的低层资源。

意向更新 (IU)

保护针对层次结构中所有低层资源请求或获取的更新锁。 仅在页资源上使用 IU 锁。 如果进行了更新操作,IU 锁将转换为 IX 锁。

共享意向更新 (SIU)

S 锁和 IU 锁的组合,作为分别获取这些锁并且同时持有两种锁的结果。 例如,事务执行带有 PAGLOCK 提示的查询,然后执行更新操作。 带有 PAGLOCK 提示的查询将获取 S 锁,更新操作将获取 IU 锁。

更新意向排他 (UIX)

U 锁和 IX 锁的组合,作为分别获取这些锁并且同时持有两种锁的结果。

 
架构锁

数据库引擎在表数据定义语言 (DDL) 操作(例如添加列或删除表)的过程中使用架构修改 (Sch-M) 锁。 保持该锁期间,Sch-M 锁将阻止对表进行并发访问。 这意味着 Sch-M 锁在释放前将阻止所有外围操作。

某些数据操作语言 (DML) 操作(例如表截断)使用 Sch-M 锁阻止并发操作访问受影响的表。

数据库引擎在编译和执行查询时使用架构稳定性 (Sch-S) 锁。 Sch-S 锁不会阻止某些事务锁,其中包括排他 (X) 锁。 因此,在编译查询的过程中,其他事务(包括那些针对表使用 X 锁的事务)将继续运行。 但是,无法针对表执行获取 Sch-M 锁的并发 DDL 操作和并发 DML 操作。

大容量更新锁
数据库引擎在将数据大容量复制到表中时使用了大容量更新 (BU) 锁,并指定了 TABLOCK 提示或使用 sp_tableoption 设置了 table lock on bulk load 表选项。 大容量更新锁(BU 锁)允许多个线程将数据并发地大容量加载到同一表,同时防止其他不进行大容量加载数据的进程访问该表。
 
键范围锁
在使用可序列化事务隔离级别时,对于 Transact-SQL 语句读取的记录集,键范围锁可以隐式保护该记录集中包含的行范围。 键范围锁可防止幻读。 通过保护行之间键的范围,它还防止对事务访问的记录集进行幻像插入或删除。