Sql Server数据库锁相关知识

Sql Server锁模式:

 

锁模式说明
共享 (S)用于不更改或不更新数据的读取操作,如 SELECT 语句。
更新 (U)用于可更新的资源中。 防止当多个会话在读取、锁定以及随后可能进行的资源更新时发生常见形式的死锁。
排他 (X)用于数据修改操作,例如 INSERT、UPDATE 或 DELETE。 确保不会同时对同一资源进行多重更新。
意向用于建立锁的层次结构。 意向锁包含三种类型:意向共享 (IS)、意向排他 (IX) 和意向排他共享 (SIX)。
架构在执行依赖于表架构的操作时使用。 架构锁包含两种类型:架构修改 (Sch-M) 和架构稳定性 (Sch-S)。
大容量更新 (BU)在向表进行大容量数据复制且指定了 TABLOCK 提示时使用。
键范围当使用可序列化事务隔离级别时保护查询读取的行的范围。 确保再次运行查询时其他事务无法插入符合可序列化事务的查询的行。

 

Sql Server可以锁定的资源:

 

 

资源说明
RID用于锁定堆中的单个行的行标识符。
KEY索引中用于保护可序列化事务中的键范围的行锁。
PAGE数据库中的 8 KB 页,例如数据页或索引页。
EXTENT一组连续的八页,例如数据页或索引页。
HoBT堆或 B 树。 用于保护没有聚集索引的表中的 B 树(索引)或堆数据页的锁。
TABLE包括所有数据和索引的整个表。
FILE数据库文件。
APPLICATION应用程序专用的资源。
METADATA元数据锁。
ALLOCATION_UNIT分配单元。
DATABASE整个数据库。

 

Sql Server数据库锁兼容性:

 

 

请求的模式

ISSUIXSIXX
意向共享 (IS)
共享 (S)
更新 (U)
意向排他 (IX)
意向排他共享 (SIX)
排他 (X)

 

锁模式:

https://msdn.microsoft.com/zh-cn/ms175519

锁兼容性(数据库引擎):

https://msdn.microsoft.com/zh-cn/ms186396

锁粒度和层次结构:

https://msdn.microsoft.com/zh-cn/ms189849

锁升级(数据库引擎):

https://msdn.microsoft.com/zh-cn/ms184286

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值