当前位置: 首页 > article >正文

【数据库系统】数据库系统概论——第十一章 并发控制

第十一章 并发控制文章目录第十一章 并发控制前言11.1并发控制概述11.2封锁11.3封锁协议11.4活锁和死锁11.4.1活锁11.4.2死锁11.5并发调度的可串行性11.5.1可串行化调度11.5.2冲突可串行化调度11.6两段锁协议11.7封锁的粒度11.7.1多粒度封锁11.7.2意向锁11.8其他并发控制机制11.8.1多版本并发控制11.8.2改进的多版本并发控制11.9小结前言多用户数据库系统是指允许多个用户同时使用的数据库系统。其特点是在同一时刻并发运行的事务数可达数百上千个,多用户数据库系统涉及并行控制。多事务执行方式(1)事务串行执行每个时刻只有一个事务运行,其他事务必须等到这个事务结束以后方能运行,不能充分利用系统资源,发挥数据库共享资源的特点。执行方式如下图:(2)交叉并发方式在单处理机系统中,事务的并行执行是这些并行事务的并行操作轮流交叉运行,单处理机系统中的并行事务并没有真正地并行运行,但能够减少处理机的空闲时间,提高系统的效率。执行方式如下图:(3)同时并发方式多处理机系统中,每个处理机可以运行一个事务,多个处理机可以同时运行多个事务,实现多个事务真正的并行运行。本章数据库系统并发控制技术是以单处理机系统为基础的。11.1并发控制概述事务是并发控制的基本单位,并发控制机制的任务是:①对并发操作进行正确调度。②保证事务的隔离性。③保证数据库的一致性。并发操作带来数据的不一致性实例。例:飞机订票系统中的一个活动序列。①甲售票点(事务T1)读出某航班的机票余额A,设A=16;②乙售票点(事务T2)读出同一航班的机票余额A,也为16;③甲售票点卖出一张机票,修改余额A←A-1,所以A为15,把A写回数据库;④乙售票点也卖出一张机票,修改余额A←A-1,所以A为15,把A写回数据库。结果明明卖出两张机票,数据库中机票余额只减少1。说明:①以上情况称为数据库的不一致性,是由并发操作引起的。在并发操作情况下,岁T1,T2两个事务的操作序列的调度是随机的。若按上面的调度序列执行,T1事务的修改就被丢失。因为第4步中T2事务修改A并写回后覆盖了T1事务的修改。②并发操作带来的数据不一致性包括丢失修改、不可重复读、读“脏”数据。③用记号R(x)表示读数据X,W(x)表示写数据X。丢失修改两个事务T1和T2读入同一数据并修改,T2的提交结果破坏了T1提交的结果,导致T1的修改被丢失。上面飞机订票的例子就属此类。不可重复读不可重复读是指事务T1读取数据后,事务T2执行更新操作,使T1无法再现一次读取结果。不可重复读包括三种情况:(1)事务T1读取某一数据后,事务T2对其做了修改,当事务T1再次读该数据时,得到与前一次不同的值。T1读取B=100进行运算。T2读取同一数据B,对其进行修改后将B=200写回数据库。T1为了对读取值校对重读B,B为200,与第一次读取值不一致。(2)事务T1按一定条件从数据库中读取了某些数据记录后,事务T2删除了其中部分记录,当T1再次按相同条件读取数据时,发现某些记录神秘地消失了。(3)事务T1按一定条件从数据库中读取某些数据记录后,事务T2插入了一些记录,当T1再次按相同条件读取数据时,发现多了一些记录。后两种不可重复读有时也称为幻影现象。读“脏”数据读“脏”数据是指读到不正确的数据。例:(1)事务T1修改某一数据,并将其写回磁盘。(2)事务T2读取同一数据后,T1由于某种原因被撤销。(3)这时T1已修改过的数据恢复原值,T2读到的数据就与数据库中的数据不一致。(4)T2读到的数据就为“脏”数据,即不正确的数据。T1将C值修改为200,T2读到C为200.T1由于某种原因撤销,其修改作废,C恢复原值100.这时T2读到C为200,与数据库内容不一致,就是“脏“数据。上面三种珊瑚橘不一致的情况主要是因为并发操作破坏了事务的隔离性。并发控制就是要用正确的方式调度并发操作,使一个用户事务的执行不受其他事务的干扰,从而避免造成数据的不一致性。对数据库的应用有时允许某些不一致性。并发控制的主要技术:封锁、时间戳、乐观控制法、多版本并发控制。11.2封锁什么是封锁封锁就是事务T在对某个数据对象(例如表、记录等)操作之前,先向系统发出请求,对其加锁。加锁后事务T就对该数据对象有了一定的控制,在事务T释放它的锁之前,其它的事务不能更新此数据对象。封锁是实现并发控制的一个非常重要的技术。基本封锁类型一个事务对某个数据对象加锁后究竟拥有什么样的控制由封锁的类型决定。基本封锁类型:排它锁(简记为X锁)、共享锁(简记为S锁)。(1)排它锁排它锁又称为写锁,若事务T对数据对象A加上X锁,则只允许T读取和修改A,其它任何事务都不能再对A加任何类型的锁,直到T释放A上的锁,保证其他事务在T释放A上的锁之前不能再读取和修改A。(2)共享锁共享锁又称为读锁,若事务T对数据对象A加上S锁,则事务T可以读A但不能修改A,其它事务只能再对A加锁,而不能加X锁,直到T释放A上的锁。保证其他事务可以读A,但在T释放A上的S锁之前不能对A做任何修改。锁的相容矩阵Y=Yes,相容的请求;N=No,不相容的请求说明:在锁的相容

相关文章:

【数据库系统】数据库系统概论——第十一章 并发控制

第十一章 并发控制 文章目录 第十一章 并发控制 前言 11.1并发控制概述 11.2封锁 11.3封锁协议 11.4活锁和死锁 11.4.1活锁 11.4.2死锁 11.5并发调度的可串行性 11.5.1可串行化调度 11.5.2冲突可串行化调度 11.6两段锁协议 11.7封锁的粒度 11.7.1多粒度封锁 11.7.2意向锁 11.8其…...

保姆级教程:用记事本写个.cmd脚本,一键解决Unity Hub安装包验证失败

一键解决Unity Hub安装包验证失败的终极脚本方案 每次打开Unity Hub都要手动设置代理?安装包验证失败的问题反复出现?今天教你用记事本写个.cmd脚本,彻底告别重复劳动。这个方案尤其适合那些不熟悉命令行操作,但又希望一劳永逸解…...

Android开发实战:利用BluetoothDevice精准获取蓝牙设备地址

1. 蓝牙设备地址的基础认知 在开始动手写代码之前,我们先要搞清楚蓝牙设备地址到底是什么。简单来说,蓝牙设备地址就像是每个蓝牙设备的身份证号码,全球唯一且不会重复。它由6个字节组成,通常表示为12个十六进制数字,中…...

内存条趋势

截至2026年4月10日,一根16GB DDR4内存条的市场价格,取决于你通过什么渠道购买: 现货市场(如华强北、电商零售):价格在 689元 至 759元 之间-2-4-10。 合约市场(品牌新机采购价)&…...

科哥版fft npainting lama图像修复:5分钟快速部署,小白也能轻松去除水印

科哥版fft npainting lama图像修复:5分钟快速部署,小白也能轻松去除水印 1. 引言:为什么选择这款图像修复工具 在日常工作和生活中,我们经常遇到需要处理图片的情况:去除水印、删除不需要的物体、修复老照片瑕疵等。…...

给你的Windows来一次“数字瘦身“:告别卡顿与干扰,重获流畅体验

给你的Windows来一次"数字瘦身":告别卡顿与干扰,重获流畅体验 【免费下载链接】Win11Debloat A simple, lightweight PowerShell script that allows you to remove pre-installed apps, disable telemetry, as well as perform various other…...

Lychee Rerank MM免配置教程:绕过HuggingFace下载直启Qwen2.5-VL重排序服务

Lychee Rerank MM免配置教程:绕过HuggingFace下载直启Qwen2.5-VL重排序服务 1. 引言:为什么需要免配置方案 如果你曾经尝试部署多模态AI模型,一定遇到过这样的烦恼:从HuggingFace下载几个GB的模型文件,网络不稳定导致…...

【Loom响应式重构黄金窗口期】:JDK21 LTS已发布,你的Java 8/17项目还剩9个月兼容缓冲期!

第一章:Loom响应式重构黄金窗口期全景洞察Java Loom 项目自JDK 21正式转为生产就绪以来,其虚拟线程(Virtual Threads)与结构化并发(Structured Concurrency)能力正深刻重塑高并发服务的架构范式。当前正处于…...

1000+ 道 Java面试题及答案整理(牛客网最新版)

作为 Java 程序员,选择学习什么样的技术?什么技术该不该学?去招聘网站上搜一搜、看看岗位要求就十分清楚了,自己具备的技术和能力,直接影响到你工作选择范围和能不能面试成功。 如果想进大厂,那就需要在 Ja…...

5个Python生物信息学实战技巧:从数据处理到机器学习完整指南

5个Python生物信息学实战技巧:从数据处理到机器学习完整指南 【免费下载链接】Bioinformatics-with-Python-Cookbook-Second-Edition 项目地址: https://gitcode.com/gh_mirrors/bi/Bioinformatics-with-Python-Cookbook-Second-Edition Python生物信息学是…...

面试必问:JDK 8有哪些新特性?这一篇彻底讲清楚

如果你也有这些困惑,那这篇文章就是为你准备的。 我用了一整天时间,把Java从1996年诞生到今天的发展历程彻底梳理了一遍。看完这篇,你不仅知道每个版本有哪些重要特性,还能明白"为什么企业都用JDK 8"、"新项目该选…...

FreeRTOS任务优先级设置不当导致系统卡死的排查与修复

1. FreeRTOS任务优先级设置不当的典型表现 在STM32F1系列单片机开发中,使用FreeRTOS时如果任务优先级设置不当,系统往往会表现出一些典型症状。最常见的就是系统运行一段时间后突然卡死,所有任务停止响应,连最基本的LED闪烁或串口…...

终极Obsidian样式定制指南:5分钟打造个性化知识管理界面

终极Obsidian样式定制指南:5分钟打造个性化知识管理界面 【免费下载链接】obsidian-style-settings A dynamic user interface for adjusting theme, plugin, and snippet CSS variables within Obsidian 项目地址: https://gitcode.com/gh_mirrors/ob/obsidian-s…...

医学信息学实战:队列研究设计与数据分析的关键要点

1. 队列研究的基本概念与核心价值 第一次接触队列研究时,我也被那些专业术语绕得头晕。直到参与了一个真实的糖尿病并发症研究项目,才真正理解这种方法的精妙之处。简单来说,队列研究就像给人群拍连续剧——把研究对象按是否接触某种因素&…...

SteamCleaner:一键释放60GB硬盘空间的专业游戏缓存清理工具

SteamCleaner:一键释放60GB硬盘空间的专业游戏缓存清理工具 【免费下载链接】SteamCleaner :us: A PC utility for restoring disk space from various game clients like Origin, Steam, Uplay, Battle.net, GoG and Nexon :us: 项目地址: https://gitcode.com/g…...

FastVideo 未来展望:下一代视频生成技术路线图分析

FastVideo 未来展望:下一代视频生成技术路线图分析 【免费下载链接】FastVideo A unified inference and post-training framework for accelerated video generation. 项目地址: https://gitcode.com/gh_mirrors/fa/FastVideo FastVideo 作为统一的视频生成…...

Rusted PackFile Manager:从零开始打造你的Total War模组

Rusted PackFile Manager:从零开始打造你的Total War模组 【免费下载链接】rpfm Rusted PackFile Manager (RPFM) is a... reimplementation in Rust and Qt5 of PackFile Manager (PFM), one of the best modding tools for Total War Games. 项目地址: https://…...

Janus-Pro-7B快速入门:10分钟完成GitHub镜像拉取与本地部署

Janus-Pro-7B快速入门:10分钟完成GitHub镜像拉取与本地部署 你是不是也对那些动辄几十上百G的大模型望而却步,觉得部署起来太麻烦?今天咱们就来聊聊Janus-Pro-7B,一个在GitHub上挺火的开源模型,我会带你用最简单的方式…...

StructBERT语义相似度分析:Docker一键部署方案,解决PyTorch兼容性问题

StructBERT语义相似度分析:Docker一键部署方案,解决PyTorch兼容性问题 1. 为什么需要这个解决方案 在自然语言处理领域,语义相似度计算是一个基础但至关重要的任务。无论是智能客服、内容推荐还是文本查重,都需要准确判断两段文…...

5步掌握Android设备远程控制:py-scrcpy-client实战指南

5步掌握Android设备远程控制:py-scrcpy-client实战指南 【免费下载链接】py-scrcpy-client 项目地址: https://gitcode.com/gh_mirrors/py/py-scrcpy-client 想要在电脑上实时查看和控制Android设备吗?py-scrcpy-client为你提供了完美的解决方案…...

带式输送机传动滚筒的设计

目 录 摘要 ………………………………………………………………………………(Ⅰ) Abstract……………………………………………………………………………(Ⅱ) 第一章 绪论………………………………………………………………………(01) 1.1概述……………………………………………...

OpenCode快速上手:3步配置本地AI编程环境,告别复杂安装

OpenCode快速上手:3步配置本地AI编程环境,告别复杂安装 1. 引言:为什么选择OpenCode? 在AI编程助手领域,OpenCode以其独特的终端优先设计和隐私安全特性脱颖而出。作为一个2024年开源的Go语言框架,它能够…...

3分钟快速优化Windows性能:Mem Reduct系统优化工具终极指南

3分钟快速优化Windows性能:Mem Reduct系统优化工具终极指南 【免费下载链接】memreduct Lightweight real-time memory management application to monitor and clean system memory on your computer. 项目地址: https://gitcode.com/gh_mirrors/me/memreduct …...

蓝桥杯单片机各模块化代码

138译码器相关,基础模块的必要工具//HC138端口选择 //通过前三位按位与,其他位数按位或的原理 //省去了部分HC138选端口的代码 //最好分开写 void InitHC138(unsigned char n) {switch(n){case 4:P2P2&0x1f; P2P2|0x80; …...

亲测有效!Xinference-v1.17.1部署避坑指南与性能调优

亲测有效!Xinference-v1.17.1部署避坑指南与性能调优 1. 引言 最近在项目里折腾AI模型服务,从零开始部署开源大模型,踩了不少坑。试过几个平台,要么配置复杂,要么性能拉胯,直到遇到了Xinference-v1.17.1。…...

PCB 相关知识

一.PCB线宽单位换算:100mil 2.54mm 。二.在1盎司的铜厚上过1A电流需要,1mm(40mil)的线宽。三:不要并排打孔,需要错位打孔:防止回流平面被割裂,绕线辐射。且增加走线空间。四.1:mark…...

猫抓Cat-Catch:如何轻松实现网页视频资源嗅探与一键下载

猫抓Cat-Catch:如何轻松实现网页视频资源嗅探与一键下载 【免费下载链接】cat-catch 猫抓 浏览器资源嗅探扩展 / cat-catch Browser Resource Sniffing Extension 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 还在为无法下载网页视频而烦恼…...

天地图(T=img_w/c)和谷歌地图(lyrs=s/m)的URL参数到底怎么用?一篇讲清所有地图瓦片服务调用细节

天地图与谷歌地图URL参数全解析:从瓦片调用到坐标系实战 当你需要在项目中集成地图服务时,是否曾被各种URL参数搞得一头雾水?Timg_w和Timg_c有什么区别?lyrss和lyrsm又代表什么?本文将彻底拆解两大主流地图服务的URL设…...

免费音频转换器fre:ac:新手也能轻松掌握的完整指南

免费音频转换器fre:ac:新手也能轻松掌握的完整指南 【免费下载链接】freac The fre:ac audio converter project 项目地址: https://gitcode.com/gh_mirrors/fr/freac 你是否曾因音频格式不兼容而烦恼?或是需要批量转换大量音乐文件却不知从何下手…...

告别代码复制:用GD32F3x0固件库V2.2.0优雅配置PWM互补输出(Keil MDK环境)

告别代码复制:用GD32F3x0固件库V2.2.0优雅配置PWM互补输出(Keil MDK环境) 在嵌入式开发中,PWM(脉冲宽度调制)技术广泛应用于电机控制、电源管理等领域。对于GD32F3x0系列微控制器,官方提供的固件…...