`
sogotobj
  • 浏览: 617769 次
  • 性别: Icon_minigender_2
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

锁的概述

阅读更多

一.为什么要引入锁

多个用户同时对数据库的并发操作时会带来以下数据不一致的问题:

丢失更新
A,B两个用户读同一数据并进行修改,其中一个用户的修改结果破坏了另一个修改的结果,比如订票系统

脏读
A用户修改了数据,随后B用户又读出该数据,但A用户因为某些原因取消了对数据的修改,数据恢复原值,此时B得到的数据就与数据库内的数据产生了不一致

不可重复读
A用户读取数据,随后B用户读出该数据并修改,此时A用户再读取数据时发现前后两次的值不一致

并发控制的主要方法是封锁,锁就是在一段时间内禁止用户做某些操作以避免产生数据不一致

二锁的分类

锁的类别有两种分法:
1.从数据库系统的角度来看:分为独占锁(即排它锁),共享锁和更新锁

MS-SQLServer使用以下资源锁模式。

锁模式描述
共享(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)锁以进行更新。由于两个事务都要转换为排它(X)锁,并且每个事务都等待另一个事务释放共享模式锁,因此发生死锁。

若要避免这种潜在的死锁问题,请使用更新(U)锁。一次只有一个事务可以获得资源的更新(U)锁。如果事务修改资源,则更新(U)锁转换为排它(X)锁。否则,锁转换为共享锁。

排它锁
排它(X)锁可以防止并发事务对资源进行访问。其它事务不能读取或修改排它(X)锁锁定的数据。

意向锁
意向锁表示SQLServer需要在层次结构中的某些底层资源上获取共享(S)锁或排它(X)锁。例如,放置在表级的共享意向锁表示事务打算在表中的页或行上放置共享(S)锁。在表级设置意向锁可防止另一个事务随后在包含那一页的表上获取排它(X)锁。意向锁可以提高性能,因为SQLServer仅在表级检查意向锁来确定事务是否可以安全地获取该表上的锁。而无须检查表中的每行或每页上的锁以确定事务是否可以锁定整个表。

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

锁模式描述
意向共享(IS)通过在各资源上放置S锁,表明事务的意向是读取层次结构中的部分(而不是全部)底层资源。
意向排它(IX)通过在各资源上放置X锁,表明事务的意向是修改层次结构中的部分(而不是全部)底层资源。IX是IS的超集。
与意向排它共享(SIX)通过在各资源上放置IX锁,表明事务的意向是读取层次结构中的全部底层资源并修改部分(而不是全部)底层资源。允许顶层资源上的并发IS锁。例如,表的SIX锁在表上放置一个SIX锁(允许并发IS锁),在当前所修改页上放置IX锁(在已修改行上放置X锁)。虽然每个资源在一段时间内只能有一个SIX锁,以防止其它事务对资源进行更新,但是其它事务可以通过获取表级的IS锁来读取层次结构中的底层资源。

独占锁:只允许进行锁定操作的程序使用,其他任何对他的操作均不会被接受。执行数据更新命令时,SQLServer会自动使用独占锁。当对象上有其他锁存在时,无法对其加独占锁。
共享锁:共享锁锁定的资源可以被其他用户读取,但其他用户无法修改它,在执行Select时,SQLServer会对对象加共享锁。
更新锁:当SQLServer准备更新数据时,它首先对数据对象作更新锁锁定,这样数据将不能被修改,但可以读取。等到SQLServer确定要进行更新数据操作时,他会自动将更新锁换为独占锁,当对象上有其他锁存在时,无法对其加更新锁。
2.从程序员的角度看:分为乐观锁和悲观锁。
乐观锁:完全依靠数据库来管理锁的工作。
悲观锁:程序员自己管理数据或对象上的锁处理。

MS-SQLSERVER使用锁在多个同时在数据库内执行修改的用户间实现悲观并发控制


三锁的粒度


锁粒度是被封锁目标的大小,封锁粒度小则并发性高,但开销大,封锁粒度大则并发性低但开销小

SQLServer支持的锁粒度可以分为为行、页、键、键范围、索引、表或数据库获取锁

资源描述
RID行标识符。用于单独锁定表中的一行。
键索引中的行锁。用于保护可串行事务中的键范围。
页8千字节(KB)的数据页或索引页。
扩展盘区相邻的八个数据页或索引页构成的一组。
表包括所有数据和索引在内的整个表。
DB数据库。


四锁定时间的长短

锁保持的时间长度为保护所请求级别上的资源所需的时间长度。

用于保护读取操作的共享锁的保持时间取决于事务隔离级别。采用READCOMMITTED的默认事务隔离级别时,只在读取页的期间内控制共享锁。在扫描中,直到在扫描内的下一页上获取锁时才释放锁。如果指定HOLDLOCK提示或者将事务隔离级别设置为REPEATABLEREAD或SERIALIZABLE,则直到事务结束才释放锁。

根据为游标设置的并发选项,游标可以获取共享模式的滚动锁以保护提取。当需要滚动锁时,直到下一次提取或关闭游标(以先发生者为准)时才释放滚动锁。但是,如果指定HOLDLOCK,则直到事务结束才释放滚动锁。

用于保护更新的排它锁将直到事务结束才释放。
如果一个连接试图获取一个锁,而该锁与另一个连接所控制的锁冲突,则试图获取锁的连接将一直阻塞到:

将冲突锁释放而且连接获取了所请求的锁。

连接的超时间隔已到期。默认情况下没有超时间隔,但是一些应用程序设置超时间隔以防止无限期等待

分享到:
评论

相关推荐

    距离保护的振荡闭锁概述.ppt

    距离保护的振荡闭锁概述.ppt

    机械的效率和自锁概述.pptx

    机械的效率和自锁概述.pptx

    MYSQL 解锁与锁表介绍

    MySQL锁概述   相对其他数据库而言,MySQL的锁机制比较简单,其最显著的特点是不同的存储引擎支持不同的锁机制。比如,MyISAM和MEMORY存储引擎采用的是表级锁(table-level locking);BDB存储引擎采用的是页面锁...

    锁的概述 (ctrl+2 sql)

    锁的概述 (ctrl+2 sql) 更新锁 排它锁 意向锁

    DB2锁问题处理最佳实践

    DB2锁问题处理最佳实践 DB2锁概述 DB2锁问题监控和定位 DB2锁问题调优 DB2 9.7锁机制深入分析 DB2锁案例分享

    数据库,各种锁的概述

    多个用户同时对数据库的并发操作时会带来以下数据不一致的问题: 丢失更新 ...并发控制的主要方法是封锁,锁就是在一段时间内禁止用户做某些操作以避免产生数据不一致 。。。。。。。。。。。。。

    RFID自动感应式车位锁方便停车场管理

    一、车位锁概述  在车位日益紧张的今天,如何避免私家车位被他人抢占,是令人头痛的事。日前面市的一种新型车位锁,不仅有效解决了这一问题,还可对车辆起到防盗作用,深受车主的喜爱。专用车位锁可以有效而礼貌地...

    RFID技术中的RFID自动感应式车位锁方便停车场管理

    一、车位锁概述  在车位日益紧张的今天,如何避免私家车位被他人抢占,是令人头痛的事。日前面市的一种新型车位锁,不仅有效解决了这一问题,还可对车辆起到防盗作用,深受车主的喜爱。专用车位锁可以有效而礼貌地...

    汽车中控门锁与防盗系统概述.pptx

    汽车中控门锁与防盗系统概述.pptx

    20XX智能锁小区活动方案概述.pdf

    20XX智能锁小区活动方案概述.pdf

    天普锁热宣传片提案概述学习教案.pptx

    天普锁热宣传片提案概述学习教案.pptx

    天普锁热宣传片提案概述PPT课件.pptx

    天普锁热宣传片提案概述PPT课件.pptx

    天普锁热宣传片提案概述PPT教案.pptx

    天普锁热宣传片提案概述PPT教案.pptx

    Mysql高级:锁

    主要二个主题:锁机制和全局机制 锁机制:概述,三锁:表锁和行锁,页锁

    fingerprint-doorlock:使用指纹传感器的电子门锁的简单固件和 GUI

    概述 使用指纹传感器的简单电子门锁。 该项目使用 ZFM-20 系列指纹传感器通过电子门锁(例如磁门蜂鸣器)实现访问控制(对建筑物或房间)。 所有指纹都可以通过称为指纹管理器的简单 GUI 或简单地通过串行终端进行...

    Oracle数据库优化概述

    1.Oracle数据库优化概述 2.性能规划器的使用 3.顶层会话的使用 4.Oracle专家的使用 5.索引调节向导 6.SQL分析的使用 7.锁管理器 8.性能管理员 9.表空间的重组 博文链接:...

    理解锁和闩:锁机制概述

    锁(lock)是一种防止多个事务访问同一资源时产生破坏性的相互影响的机制。通常,高并发数据库需要利用锁机制解决数据并发访问、一致性及完整性问题。  前面提到的资源(resource)大致可以分为两类:  ● ...

    智能楼宇概述.pptx

    智能建筑综合管理系统(MA) 综 合 布 线 系 统(SCS) 办公自动化(OA) 楼宇自动化(BA) 通信自动化(CA) 保安自动化(SA) 消防自动化(FA) 智能楼宇系统组成 智能楼宇概述全文共25页,当前为第5页。...

    智能门锁控制电路_单片机

    一、 设计概述 在日常的生活和工作中,家居住宅的安全防范、单位中文件档案、财务报表等资料保存,多以上锁的方法予以解决。如果使用传统的机械式锁,人们需要多条钥匙,携带极不方便,且存在钥匙丢失后安全性隐患。...

    Android jni 线程同步

    文章目录概述问题示例c++层java层结果解决办法java层加锁c++层加锁java层和c++层共用一个锁 概述 android中可以通过jni调用native的方法,那么如果在java中存在多个线程调用native的方法,它的展现形式是如何呢? 先...

Global site tag (gtag.js) - Google Analytics