位置: 编程技术 - 正文

为什么我们需要在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语句执行效率)

  • Symfony2实现在doctrine中内置数据的方法

    Symfony2实现在doctrine中内置数据的方法

  • SQL Server2008 R2 数据库镜像实施手册(双机)SQL Server2014同样适用(sqlserver2008r2数据库导出教程)

    上图中将“恢复模式”选成“完整模式”。

    2、备份数据库,如下图:

    备份时将“备份类型”选成“完整”。

    3、备份事务日志,如下图:

    将“备份类型”选成“事务日志”且备份目录与备份数据库的目录一致。

    将备份文件在备机上使用主机的全备文件进行还原,在还原数据的时候需要使用选上“with non recover”。如图所示:

    如果执行成功数据库将会变成这个样子:

    3、 建立镜像

    说明:shishan为数据库名,需要根据实际进行修改。..1.为备机IP地址,需根据实际进行修改。

    执行成功后:

    到此,SQL镜像热备配置完成。

    四、常见命令

    备份主数据库出现:Backup a database on a HDD with a different sector size,可以执行以下语句备份:BACKUP DATABASE MyDB TO DISK = N'D:MyDB.bak' WITH INIT , NOUNLOAD , NAME = N'MyDB backup" class="img-responsive" alt="SQL Server2008 R2 数据库镜像实施手册(双机)SQL Server2014同样适用(sqlserver2008r2数据库导出教程)">

    SQL Server2008 R2 数据库镜像实施手册(双机)SQL Server2014同样适用(sqlserver2008r2数据库导出教程)

  • win10退回win8系统后出现蓝屏提示system_service_exception(win32ksys)的解决方法(win8.1退回win8)

    win10退回win8系统后出现蓝屏提示system_service_exception(win32ksys)的解决方法(win8.1退回win8)

  • KVM虚拟机上关于宿主机的USB设备使用问题探究(kvm虚拟机运行方式)

    KVM虚拟机上关于宿主机的USB设备使用问题探究(kvm虚拟机运行方式)

  • Mac Book到底能不能取代超极本?(macbook key)

    Mac Book到底能不能取代超极本?(macbook key)

  • DOS批处理高级教程 第五章 set命令详解(dos批处理命令大全)

    DOS批处理高级教程 第五章 set命令详解(dos批处理命令大全)

  • LayoutInflater.inflate方法解析

    LayoutInflater.inflate方法解析

  • cocos2dx3.2 整体概览(四)—— Sprite(精灵)(cocos2dx 2.2.2)

    cocos2dx3.2 整体概览(四)—— Sprite(精灵)(cocos2dx 2.2.2)

  • nagios 分发文件实现代码(ipa文件分享)

    nagios 分发文件实现代码(ipa文件分享)

  • dos命令 cd命令使用说明[图文说明](dos命令chkdsk)

    dos命令 cd命令使用说明[图文说明](dos命令chkdsk)

  • 3、BluetoothChat之BluetoothChatService.java

    3、BluetoothChat之BluetoothChatService.java

  • 递延所得税负债账务处理
  • 购买财务软件费用入什么科目
  • 留存收益的个别资本成本率计算公式
  • 什么是非限制
  • 房地产企业增值税管理办法
  • 印花税的计税依据为各种应税凭证上所记载的计税金额
  • 债券投资收益怎样计算
  • 工资发放凭证由谁出具
  • 2019年计算机软件行业人均年工资
  • 模具费进研发费用还是成本
  • 扣缴义务人是否可以领税务发票,是否可以正常申报
  • 免税即征即退先征后退
  • 营改增前甲供材料如何纳税
  • 产品成本科目包括
  • 国税开运输发票后地税怎么报税?
  • 免税的和不免税的可以开在一张发票上吗
  • 收到员工补缴的公积金怎么入账
  • 发票专用章是个人
  • 已经认证的发票怎么冲红
  • 个人所得汇算清缴是什么
  • u盘启动盘如何分区
  • 支付商品展览费计入
  • uefiu盘安装系统步骤win10
  • 电脑上fci是什么文件
  • php ado
  • 微软即将终止当前系统版本
  • cpu版本的pytorch可以运行LSgan嘛
  • 工业企业成本核算的内容是
  • laravel php
  • 钉钉工资表如何生成工资条?
  • 前端处理map
  • vue快速入门与实战开发
  • ChatGPT助力校招----面试问题分享(四)
  • 增值税专用发票和普通发票的区别
  • css媒体查询不起作用
  • 苗木可以进项抵扣的么
  • 外省人员收入怎么查
  • 预缴的附加税需要转出吗
  • 预缴所得税可以调减吗
  • 白酒贴牌酒是真酒还是假酒
  • 企业股东分红可抵税吗
  • 哪些凭证是免纳税的
  • 公司注销其他应收款怎么冲平
  • 帐外资金
  • 初始化流程
  • 企业当期营业收入的计算
  • 水电费没有发票吗
  • 有限合伙企业分红原则
  • 公司员工年薪如何发放
  • 净资产越来越少会有什么风险
  • 营改增后建筑业分公司账务
  • 支付厂房租赁费现金流
  • 工程预交税金是什么意思
  • 费用设置的明细科目
  • haproxy教程
  • centos如何运行程序
  • win7出现问题
  • win8.1操作系统关闭驱动数字签名
  • windows与linux的关系
  • ubuntu作为开发环境
  • linux命令行在哪
  • 禅道界面
  • linux的newgrp
  • win8怎么添加桌面
  • dosbox批处理
  • three.js dispose
  • 批处理有何限制
  • nodejs filereader
  • 安卓 图形api
  • 基于android的app
  • css中文字垂直排列
  • js控制鼠标位置
  • get调用接口
  • android在手机上运行
  • jsonp怎么使用
  • 大连税务登记app
  • 狠抓组织收入工作
  • 养老专业在职研究生好吗
  • 1国家税务总局
  • 结售汇选择汇还是钞好
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设