SQLServer的锁机制

本文介绍了SQLServer的锁机制,包括锁的引入原因、分类(独占锁、共享锁、更新锁、意向锁等)、锁的粒度、锁定时间以及如何避免死锁。详细讲解了各种锁的作用和应用场景,有助于理解并发控制和数据库事务的管理。
摘要由CSDN通过智能技术生成
  1. 最近因为要写一个数据并发访问的控制程序,上网查了一些资料,现在归纳如下:
  2. 锁的概述
    1. 一. 为什么要引入锁
      多个用户同时对数据库的并发操作时会带来以下数据不一致的问题:
      丢失更新
      A,B两个用户读同一数据并进行修改,其中一个用户的修改结果破坏了另一个修改的结果,比如订票系统
           脏读
      A用户修改了数据,随后B用户又读出该数据,但A用户因为某些原因取消了对数据的修改,数据恢复原值,此时B得到的数据就与数据库内的数据产生了不一致
      不可重复读
      A用户读取数据,随后B用户读出该数据并修改,此时A用户再读取数据时发现前后两次的值不一致
      并发控制的主要方法是封锁,锁就是在一段时间内禁止用户做某些操作以避免产生数据不一致
      二 锁的分类
      锁的类别有两种分法:
      1. 从数据库系统的角度来看:分为独占锁(即排它锁),共享锁和更新锁
      MS SQL Server 使用以下资源锁模式。
      锁模式 描述
      共享 (S) 用于不更改或不更新数据的操作(只读操作),如 SELECT 语句。
      更新 (U) 用于可更新的资源中。防止当多个会话在读取、锁定以及随后可能进行的资源更新时发生常见形式的死锁。
      排它 (X) 用于数据修改操作,例如 INSERT、UPDATE 或 DELETE。确保不会同时同一资源进行多重更新。
      意向锁 用于建立锁的层次结构。意向锁的类型为:意向共享 (IS)、意向排它 (IX) 以及与意向排它共享 (SIX)。
      架构锁 在执行依赖于表架构的操作时使用。架构锁的类型为:架构修改 (Sch-M) 和架构稳定性 (Sch-S)。
      大容量更新 (BU) 向表中大容量复制数据并指定了 TABLOCK 提示时使用。
      共享锁
      共享 (S) 锁允许并发事务读取 (SELECT) 一个资源。资源上存在共享 (S) 锁时,任何其它事务都不能修改数据。一旦已经读取数据,便立即释放资源上的共享 (S) 锁,除非将事务隔离级别设置为可重复读或更高级别,或者在事务生存周期内用锁定提示保留共享 (S) 锁。
      更新锁
      更新 (U) 锁可以防止通常形式的死锁。一般更新模式由一个事务组成,此事务读取记录,获取资源(页或行)的共享 (S) 锁,然后修改行,此操作要求锁转换为排它 (X) 锁。如果两个事务获得了资源上的共享模式锁,然后试图同时更新数据,则一个事务尝试将锁转换为排它 (X) 锁。共享模式到排它锁的转换必须等待一段时间,因为一个事务的排它锁与其它事务的共享模式锁不兼容&#x
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值