位置: 编程技术 - 正文

为什么我们需要在SQL Server里更新锁(为什么我们需要政府)

编辑:rootadmin

推荐整理分享为什么我们需要在SQL Server里更新锁(为什么我们需要政府),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:为什么我们需要规则意识,为什么我们需要文学,为什么我们需要志愿者作文英语,为什么我们需要真诚友善的朋友,为什么我们需要文学,为什么我们需要文学,为什么我们需要文学,为什么我们需要真诚友善的朋友,内容如对您有帮助,希望把文章链接给更多的朋友!

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

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

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

Notice: Undefined index: CMSdown in /data/webroot/gcms/lib/Api/Open/Article.php on line img////_ddda8.png" alt="查看图片" />

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

为什么我们需要在SQL Server里更新锁(为什么我们需要政府)

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

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

Notice: Undefined index: CMSdown in /data/webroot/gcms/lib/Api/Open/Article.php on line img////_de2ebb0.png" alt="查看图片" />

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

提升的并发

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

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

小结在今天的文章里我给你介绍了共享锁,还有为什么需要共享锁。如你所见在关系数据库,是强烈需要更新锁的,因为不然的就会带来死锁并降低并发。我希望现在你已经很好的理解了更新锁,还有在SQL Server里它们是如何使用的。

标签: 为什么我们需要政府

本文链接地址:https://www.jiuchutong.com/biancheng/347420.html 转载请保留说明!

上一篇:简单介绍SQL Server里的闩锁(简单介绍清明上河图)

下一篇:如何优化SQL语句(全)(如何优化sql语句执行效率)

  • 食品配送专票税率是多少
  • 对公账户要收手续费吗
  • 专家劳务费可以税前扣除吗
  • 出差的招待费怎么报销
  • 个税身份证验证不通过已经申报缴税
  • 居民企业参股外国企业信息报告填写
  • 新会计准则开办费分摊
  • 职工食堂支出明细表
  • 对公网银支付方式可以选哪些
  • 农产品收购发票图片
  • 简易计税方法是什么意思
  • 技术转让怎么算成本
  • 董事监事的报酬包括哪些
  • 本年已预缴所得税
  • 亏损企业所得税汇算清缴怎么做
  • 非直系亲属继承房产后再卖掉后交税吗
  • 企业所得税为15%的企业
  • 企业所得税汇算清缴网上申报流程
  • 融资租赁业务如何纳税
  • 费用应计入管理费用的有
  • 不是公司员工差评怎么写
  • 出差的住宿费较高的原因
  • 初级考试判断题怎么扣分
  • 毛利率计算公式举例说明
  • find.exe应用程序错误
  • 制药企业成本核算流程
  • 二手房房屋买卖注意哪些问题
  • 其他应收款的审计重点不包括哪些
  • php登录注册页面完整代码
  • c++ 每日十问3-处理数据
  • 企业预缴增值税附加税率
  • 企业残保金怎样申报
  • 注册公司时的注册资金
  • 微信小程序云开发控制台
  • 法人跟纳税人必须是一个人吗
  • python爬取网站数据毕业论文
  • c语言设计酒店管理系统
  • 利润表所得税费用怎么算
  • 小规模纳税人研发费用加计扣除优惠政策
  • python replace 多个
  • 公司签发银行承兑汇票的行为属于什么
  • 附加税多计提了怎么调整
  • 溢价收购公司会计处理
  • mysql 执行动态语句
  • mysql几千万条数据
  • 固定资产加速折旧是什么意思
  • 中餐补助
  • 小微企业开专票需要缴纳多少税
  • 增值税加计扣除最新政策2023
  • 进项税额抵扣如何做账
  • 车船税不开发票怎么做账?
  • 销项100万进项80万交多少税
  • 购入厂部用小汽车一部是管理费用吗
  • 房地产企业按简易计税
  • 生产企业出口退税政策
  • 外包加工如何做账
  • 残保金工资总额是按计提还是发放
  • 小微企业即征即退
  • 企业开发有多个产品
  • 进项发票已认证未抵扣分录
  • win8系统的运行在哪里打开
  • arp攻击的原理及防范
  • win10系统中怎么打开IE浏览器
  • centos7修改远程登录端口
  • windows系统同时按下CTRL+ALT+DEL键没有弹出任务管理器的解决方法
  • win8怎么禁止弹窗
  • ins pc版
  • win10系统升级后共享打印机不能用
  • opengl3d
  • 置顶在线
  • js用什么编写
  • python中random模块用法
  • js拖拽效果
  • jquery版本区别
  • 个体工商户年报补报流程
  • 广西壮族自治区图书馆
  • 新疆12366电子税务局官网手机版
  • 完税证明可以自己在家打印吗
  • 12345市民热线什么时候有的
  • 电子税务局备案财务会计制度
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设