【数据库系统概论】第第12章 并发控制

12.1 并发控制概述

并发控制是指数据库管理系统(DBMS)通过控制多个事务同时执行,保证数据的一致性和隔离性,避免事务间的相互干扰。

事务串行执行不能充分利用系统资源

并发执行的优点:能够减少处理机的空闲 时间,提高系统的效率

并发执行可能引发的问题

会产生多个事务同时存取同一数据的情况可能会存取和存储不正确的数据,破坏事务一致性和数据库的一致性
 

丢失修改(Lost Update)

两个事务对同一数据进行更新,其中一个事务的更新被覆盖

读“脏”数据(Dirty Read)

一个事务读取到另一个未提交事务修改的数据

不可重复读(Non-Repeatable Read)

一个事务在多次读取同一数据时,由于其他事务的修改,导致读取的结果不一致

幻读(Phantom Read)

一个事务在多次查询时,结果集因其他事务的插入或删除发生变化

幻读也称作幻影(phantom row)现象,是指事务T1读取数据后,事务T2执行插入或删除操作,使T1无法再现前一次读取结果。

(1)事务T1按一定条件从数据库中读取某些数据记录后,事务T2删 除了其中部分记录,当T1再次按相同条件读取数据时,发现某些记 录“神秘地”消失了。

(2)事务T1按一定条件从数据库中读取某些数据记录后,事务T2插 入了一些记录,当T1再次按相同条件读取数据时,发现多了一些记录

数据不一致性原因:由于并发操作破坏了事务的隔离性

并发控制就是要用正确的方式调度并发操作,使一个 用户事务的执行不受其他事务的干扰,从而避免造成数据 的不一致性

12.2 事务的隔离级别

事务隔离级别定义了一个事务与其他事务之间的隔离程度。SQL标准定义了以下四种隔离级别:

读未提交、读已提交、可重复读、可串行化

读未提交(Read Uncommitted)

“读未提交”是允许一个事务可以读取另一个未提交事务正在修改的数据。(允许读,不允许写

存在问题:可能出现      脏读、不可重复读、幻读。

读已提交(Read Committed)

只允许一个事务读其他事务已提交的数据。显然, “读已提交”可以有效避免读脏读

存在问题:不可重复读、幻读

可重复读(Repeatable Read)

“可重复读”是一个事务开始读取数据后,其他事务就不能再对该数据执行UPDATE操作了。

存在问题:幻读。

可串行化(Serializable)

最严格的隔离级别

事务按顺序逐一执行,完全避免了并发问题。

存在问题:性能开销较大。

  事务隔离级别并不是越高越好 ,应根据应用的特点和需求选择合适的事务隔离级别

MySql的默认级别是“可重复读"

12.3 封锁

商用的DBMS一般都采用封锁方法

  封锁是一种常见的并发控制机制,用于保证事务隔离性。

封锁就是事务T在对某个数据对象(例如表、记录等)操 作之前,先向系统发出请求,对其加锁

加锁后事务T就对该数据对象有了一定的控制,在事务T释放它的锁之前,其它的事务不能更新此数据对象

封锁的类型

  1. 排他锁(X锁)又称为写锁,允许事务读取和修改数据,但其它任何事务都不能再对A加任何类型的锁,

    直到T释放A上的锁
  2. 共享锁(S锁)又称为读锁,允许多个事务同时读取数据,但不能修改。若事务T对数据对象A加上S锁,则其它事务只能再对A 加S锁,而不能加X锁,直到T释放A上的S锁

封锁的粒度

  1. 表级封锁:对整个表加锁,适用于大批量操作,但并发度低。

  2. 行级封锁:对表中某一行加锁,并发度高,但开销较大。

12.4 封锁协议

封锁协议是事务加锁与解锁的规则【何时申请X锁或S锁 ,持锁时间 ,何时释放

对封锁方式规定不同的规则,就形成了各种不同的封锁协议

三级封锁协议

一级封锁协议

事务T在修改数据R之前必须先对其加X锁,直到事务结束才释放。

正常结束(COMMIT) ;非正常结束(ROLLBACK)

可防止丢失修改

二级封锁协议

一级封锁协议加上事务T在读取数据R之前必须先对其加S锁,读完后即可释放S锁

可以防止丢失修改和读“脏”数据

三级封锁协议

一级封锁协议加上事务T在读取数据R之前必须先对其加S锁, 直到 事务结束 才释放

可以解决4个问题

12.5 活锁与死锁

封锁技术可以有效地解决并行操作的一致性问题,但也带来一些新的问题

1. 活锁(Livelock):事务虽然在持续执行,但由于不断被让步,导致无法继续完成自己的任务。

  • 原因:频繁的资源让步或优先级调度机制。

  • 解决方法:采用公平调度策略。引入随机性,避免资源竞争的循环。

2. 死锁(Deadlock):两个或多个事务因相互持有对方需要的资源,导致相互等待,无法继续执行。

解决方法死锁预防:采用一次性申请所有资源策略。规定加锁顺序,避免循环等待

                死锁检测与解除:定期检测等待图,发现死锁后中止某个事务释放资源

                超时机制为每个事务设定超时时间,超时后自动终止并释放资源

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/973838.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

阿里云通过docker安装skywalking及elasticsearch操作流程

系统 本文使用系统为 Alibaba Cloud Linux 3.2104 LTS 64位 配置为 4核8G PS:最低配置应为2核4G,配置过低无法启动 安装docker 1.卸载旧版本docker yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-…

【分治法】循环赛日程表问题 C\C++(附代码、实例)

问题描述 设计一个满足以下要求的比赛日程表: 每位选手必须与其他n-1个选手各赛一次每位选手一天只能赛一次循环赛一个进行n-1天选手人数 n 2 k n2^k n2k 问题分析 下图是一种日程表的安排方式 观察上图,我们发现日程表左上角的四行四列和右下角的四…

【第一节】C++设计模式(创建型模式)-工厂模式

目录 前言 一、面向对象的两类对象创建问题 二、解决问题 三、工厂模式代码示例 四、工厂模式的核心功能 五、工厂模式的应用场景 六、工厂模式的实现与结构 七、工厂模式的优缺点 八、工厂模式的扩展与优化 九、总结 前言 在面向对象系统设计中,开发者常…

基于windows的docker-desktop安装kubenetes以及dashboard

我们需要k8s环境做各种小实验可以本地安装一个,这里介绍win11如何通过docker-desktop安装k8s以及通过helm安装dashboard。 下载docker-desktop地址https://www.docker.com/get-started/打开【控制面板】->打开【启用和关闭windows功能】->分别勾选【hyper-v】…

vmware虚拟机Ubuntu Desktop系统怎么和我的电脑相互复制文件、内容

1、先安装vmware workstation 17 player,然后再安装Ubuntu Desktop虚拟机,然后再安装vmware tools,具体可以参考如下视频: VMware虚拟机与主机实现文件共享,其实一点也不难_哔哩哔哩_bilibili 2、本人亲自试过了&…

AIGC视频扩散模型新星:SVD——稳定扩散的Video模型

大家好,这里是好评笔记,公主号:Goodnote,专栏文章私信限时Free。本文详细介绍慕尼黑大学携手 NVIDIA 等共同推出视频生成模型 Video LDMs。NVIDIA 在 AI 领域的卓越成就家喻户晓,而慕尼黑大学同样不容小觑,…

llama-factory部署微调方法(wsl-Ubuntu Windows)

llama-factory项目GitHub地址:GitHub - hiyouga/LLaMA-Factory: Unified Efficient Fine-Tuning of 100 LLMs & VLMs (ACL 2024) wsl-Ubuntu: 1.获取项目 git clone https://github.com/hiyouga/LLaMA-Factory.gitcd LLaMA-Factory/ 2.安装环境…

数据结构之【顺序表简介】

1.顺序表的概念 顺序表 是 用一段物理地址连续的存储单元 依次 存储数据元素的线性结构 一般情况下采用数组存储 2.顺序表的结构 既然顺序表可以用来存储数据元素, 那就少不了 增删查改 的操作 此时,单一地只创建数组满足不了上述操作 创建相应的结构…

基于Spring Boot的农产品智慧物流系统设计与实现(LW+源码+讲解)

专注于大学生项目实战开发,讲解,毕业答疑辅导,欢迎高校老师/同行前辈交流合作✌。 技术范围:SpringBoot、Vue、SSM、HLMT、小程序、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、安卓app、大数据、物联网、机器学习等设计与开发。 主要内容:…

具有整合各亚专科医学领域知识能力的AI智能体开发纲要(2025版)

整合各亚专科医学领域知识能力的AI代理的开发与研究 一、引言 1.1 研究背景 在科技飞速发展的当下,人工智能(AI)已成为推动各行业变革的关键力量,医疗领域也不例外。近年来,AI 在医疗行业的应用取得了显著进展,从医学影像诊断到疾病预测,从药物研发到个性化医疗,AI 技…

【Redis】在Java中以及Spring环境下操作Redis

Java环境下&#xff1a; 1.创建maven 项目 2.导入依赖 <!-- redis --><dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version>4.3.2</version></dependency> 此处使用的是Jedis&…

功能说明并准备静态结构

功能说明并准备静态结构 <template><div class"card-container"><!-- 搜索区域 --><div class"search-container"><span class"search-label">车牌号码&#xff1a;</span><el-input clearable placeho…

【华三】STP的角色选举(一文讲透)

【华三】STP的角色选举 一、引言二、STP基础概念扫盲三、根桥选举过程详解四、根端口选举过程详解五、指定端口选举过程详解六、阻塞端口七、总结与配置建议七、附录**1. BPDU字段结构图&#xff08;文字描述&#xff09;****2. 华三STP常用命令速查表** 文章总结 一、引言 在…

LangChain 技术入门指南:探索语言模型的无限可能

在当今的技术领域&#xff0c;LangChain 正逐渐崭露头角&#xff0c;成为开发语言模型应用的强大工具。如果你渴望深入了解并掌握这一技术&#xff0c;那么就跟随本文一起开启 LangChain 的入门之旅吧&#xff01; (后续将持续输出关于LangChain的技术文章,有兴趣的同学可以关注…

【设计模式精讲】创建型模式之原型模式(深克隆、浅克隆)

文章目录 第四章 创建型模式4.5 原型模式4.5.1 原型模式介绍4.5.2 原型模式原理4.5.3 深克隆与浅克隆4.5.4 原型模式应用实例4.5.5 原型模式总结 个人主页&#xff1a;道友老李 欢迎加入社区&#xff1a;道友老李的学习社区 第四章 创建型模式 4.5 原型模式 4.5.1 原型模式介…

【uniapp*vue3】app/h5 webview通讯方案

本文旨在解决vue3版本下uniapp h5项目向app项目中webview通讯问题 问题产生于uniapp不支持vue3使用template.h5.html 自定义打包模板 h5向app发送信息 有很多文章指出h5项目使用uni.postmessage 这个api需要在template.h5.html引入一个js文件 然后改下webuni变量再从manifest.…

关于Bootstrap的前端面试题及其通俗易懂的答案解析

文章目录 1. 什么是Bootstrap&#xff1f;2. Bootstrap的主要特点有哪些&#xff1f;3. Bootstrap中的栅格系统是如何工作的&#xff1f;4. 如何在Bootstrap中创建一个按钮&#xff1f;5. 如何使一个元素在Bootstrap中可见或隐藏&#xff1f;6. Bootstrap中的导航栏是如何工作的…

POI优化Excel录入

57000单词原始录入时间258S 核心代码: List<Word> wordBookList ExcelUtil.getReader(file.getInputStream()).readAll(Word.class);if (!CollectionUtil.isEmpty(wordBookList)) {for (Word word : wordBookList) {//逐条向数据库中插入单词wordMapper.insert(word);}…

重订货点和安全库存

重订货点 重订货点是指当库存水平下降到某个特定值时&#xff0c;系统会自动触发采购或生产订单。其目的是确保在物料消耗完之前&#xff0c;能够及时补充库存。 安全库存 安全库存是为应对未来物资供应或需求的不确定性因素&#xff08;如突发性订货、交货期突然延期等&…

axios post请求 接收sse[eventsource]数据的

axios 接收sse数据的 axios 接收sse数据的 EventSource什么 基于 HTTP 协议实现&#xff0c;通过与服务器建立一个持续连接&#xff0c;实现了服务器向客户端推送事件数据的功能。在客户端&#xff0c;EventSource 对象通过一个 URL 发起与服务器的连接。连接成功后&#xff0…