iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >为什么我们需要在SQL Server里更新锁
  • 629
分享到

为什么我们需要在SQL Server里更新锁

2024-04-02 19:04:59 629人浏览 八月长安
摘要

为什么我们需要在SQL Server里更新锁,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。每次讲解sql Server里的锁和阻塞(Locki

为什么我们需要在SQL Server里更新,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

每次讲解sql Server里的锁和阻塞(Locking & Blocking)都会碰到的问题:在SQL Server里,为什么我们需要更新锁?在我们讲解具体需要的原因前,首先我想给你介绍下当更新锁(Update(U)Lock)获得时,根据它的兼容性锁本身是如何应对的。

一般来说,当执行UPDATE语句时,SQL Server会用到更新锁(Update Lock)。如果你查看对应的执行计划,你会看到它包含3个部分:

读取数据计算新值写入数据

在查询计划的第1部分,SQL Server初始读取要修改的数据,在各个记录上会获得更新锁(Update Locks)。在查询计划的最后第3部分,当数据被修改时,这些更新锁(Update Locks)转化为排它锁(Exclusive(X))。用这个方法产生的问题都是一样的:在第1个阶段,SQL Server为什么要获得更新锁(Update Locks),而不是共享锁(Shared(S) Locks)。平常当你通过SELECT语句读取数据,共享锁(Shared(S) Locks)已经够用了。现在的更新查询计划为什么有这个区别?我们来详细分析下。

回避死锁(Deadlock Avoidance)首先在更新查询计划里,更新锁用来避免死锁情形。假设在计划的第1阶段,有多个更新查询计划获得共享锁(Shared(S)Locks),然后在查询计划的第3阶段,当数据最后被修改时,这些共享锁(Shared Locks)转化为排它锁(Exclusive Loks),会发生什么:

第1个查询不能转化共享锁为排它锁,因为第2个查询已经获得了共享锁。第2个查询不能转化共享锁为排它锁,因为第1个查询已经获得了共享锁。

这是其中一个主要原因,为什么关系数据库引擎引入更新锁来实现避免特定的死锁情形。一个更新锁只与一个共享锁兼容,但不与另一个更新或排它锁兼容。因此死锁情形可以被避免,应为2个更新查询计划不可能同时并发运行。在查询的第1阶段,第2个查询会一直等到获得更新锁。System R的一个未公开研究也展示如何避免这类显著的死锁。System R不实用任何更新锁来实现避免死锁。

提升的并发

在第1阶段不获得更新锁,在这个阶段直接获得排它锁也是可见选项。这会克服死锁问题,因为排它锁与另一个排它锁不兼容。但这个方法的问题是并发受限制,因为同时没有其他的SELECT查询可以读取当前有排它锁的数据。因此需要更新锁,因为这个特定锁与传统的共享锁兼容。这样的话其他的SELECT查询可以读取数据,只要这个更新锁还没转化为排它锁。作为副作用,这会提高我们并发运行查询的并发性。

在以前关系学术上,更新锁是所谓的非对称锁(Asymmetric Lock)。在更新锁的上下文里,这个更新锁与共享锁兼容,但反之就不是:共享锁与更新锁不兼容。但SQL Server并不把共享锁作为非对称锁实现。更新锁是个对称(symmetric)的,就是说更新锁和共享锁是彼此双向兼容的。这会提供系统的整体并发,因为在2个锁类型键不会引入阻塞情形。

如你所见在关系数据库,是强烈需要更新锁的,因为不然的就会带来死锁并降低并发。

看完上述内容,你们掌握为什么我们需要在SQL Server里更新锁的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网数据库频道,感谢各位的阅读!

您可能感兴趣的文档:

--结束END--

本文标题: 为什么我们需要在SQL Server里更新锁

本文链接: https://www.lsjlt.com/news/69005.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 为什么我们需要在SQL Server里更新锁
    为什么我们需要在SQL Server里更新锁,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。每次讲解SQL Server里的锁和阻塞(Locki...
    99+
    2024-04-02
  • 数据库中为什么我们需要使用键
    这篇文章将为大家详细讲解有关数据库中为什么我们需要使用键,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。为什么我们需要使用键?在实际应用中,存储数据所需的表的数量很大,并且...
    99+
    2024-04-02
  • 为什么网站需要定期更新
    提升用户体验:定期更新网站可以增加新的内容和功能,使用户在访问网站时获得新的体验,增加用户的粘性和活跃度。 提升搜索引擎排名...
    99+
    2024-04-17
    建站
  • Numpy容器在Python中的作用:为什么你需要了解它们?
    在Python编程中,Numpy容器是不可或缺的一部分。Numpy是一个Python库,它提供了用于处理大型多维数组和矩阵的工具。它是Python科学计算的基础,因此,了解Numpy容器及其功能是必不可少的。 Numpy数组是一个高效的、...
    99+
    2023-09-08
    容器 numpy 日志
  • 服务器安全补丁:为什么你需要定期更新?
    在当今数字时代,服务器已成为企业运营的核心组成部分。服务器存储和处理大量敏感数据,包括客户信息、财务数据和业务秘密。因此,保护服务器免受安全威胁至关重要。 服务器安全补丁是保护服务器免受最新威胁的必要步骤。软件开发人员经常发现软件中的漏...
    99+
    2024-02-27
    服务器安全补丁、软件更新、漏洞、安全风险
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作