4种事务隔离级别 3种异常现象 死锁

news2024/11/26 18:34:58

4种事务隔离级别 & 3种异常现象

4种事务隔离级别和3种异常现象

事务隔离级别是指多个并发事务之间相互隔离的程度,用于控制事务对数据库的读取和写入操作的可见性和影响范围。在关系数据库管理系统(RDBMS)中,常见的事务隔离级别包括以下四个级别:

  1. 读未提交(Read Uncommitted):

    • 最低的隔离级别,事务中的修改可以被其他事务读取,即未提交的修改对其他事务是可见的。
    • 存在脏读(Dirty Read)的问题,即一个事务读取到了另一个未提交事务的数据。
  2. 读已提交(Read Committed):

    • 读已提交是默认的隔离级别。
    • 一个事务只能读取到已经提交的数据,避免了脏读的问题。
    • 但在并发环境下,可能出现不可重复读(Non-Repeatable Read)问题,即同一个事务内多次读取同一行数据,结果不一致。
  3. 可重复读(Repeatable Read):

    • 保证了在一个事务中多次读取同一数据时,结果始终一致。
    • 其他事务在当前事务提交之前不能修改当前事务中涉及的数据,避免了不可重复读的问题。
    • 但在并发环境下,可能出现幻读(Phantom Read)问题,即同一个查询多次执行,返回的结果集不同。
  4. 串行化(Serializable):

    • 最高的隔离级别,确保了事务的完全隔离性。
    • 所有事务依次串行执行,避免了脏读、不可重复读和幻读的问题。
    • 但串行执行会降低并发性能,通常只在必要时才使用。

选择适当的事务隔离级别取决于应用程序的要求和并发访问的特点。较低的隔离级别可以提高并发性能,但可能引入数据不一致的问题。较高的隔离级别可以保证数据的一致性,但会降低并发性能。在实际应用中,需要根据具体情况进行权衡和选择。

在MySQL中,默认的事务隔离级别是“可重复读”(Repeatable Read)。可以使用SET TRANSACTION ISOLATION LEVEL语句来显式设置事务的隔离级别。同时,MySQL也支持通过锁机制来实现更细粒度的并发控制,例如行锁和表锁。

请注意,在某些特殊场景下,如需要实现更高级的并发控制或避免特定的并发问题时,可能需要对事务隔离级别进行额外的
在这里插入图片描述
不同级别解决的问题
在这里插入图片描述

InnoDB锁分类
在这里插入图片描述

悲观锁 & 乐观锁

悲观锁和乐观锁是两种并发控制的策略,常用于多个并发事务同时访问共享资源时的数据一致性保护。它们的区别在于对于并发冲突的处理方式。

  1. 悲观锁(Pessimistic Locking):

    • 悲观锁假设会发生并发冲突,因此在事务访问数据时会对数据进行加锁,防止其他事务同时修改数据。
    • 当一个事务访问数据时,会将数据加上排他锁,其他事务必须等待该锁释放才能访问该数据。
    • 悲观锁适用于并发冲突较为频繁的场景,能够确保数据的一致性,但并发性能较差。
  2. 乐观锁(Optimistic Locking):

    • 乐观锁假设并发冲突的概率较低,因此在事务访问数据时不对数据加锁,而是在提交事务时检查数据是否发生了冲突。
    • 事务在读取数据时会记录一个版本号或时间戳,提交事务时会检查版本号或时间戳是否被其他事务修改过,如果没有则提交成功,否则回滚事务。
    • 乐观锁适用于并发冲突较少的场景,能够提高并发性能,但需要处理并发冲突的回滚和重试机制。

悲观锁和乐观锁的选择取决于应用场景和数据访问特点。悲观锁适合并发冲突较频繁的场景,确保数据的一致性,但可能牺牲了并发性能。乐观锁适合并发冲突较少的场景,能够提高并发性能,但需要额外的冲突处理机制。

在实际应用中,可以根据具体的业务需求和性能要求选择合适的并发控制策略。有时也可以根据具体的数据访问模式,结合使用悲观锁和乐观锁来获得更好的性能和数据一致性。
在这里插入图片描述
脏读、不可重复读、换读

死锁?
在这里插入图片描述
脏读
在这里插入图片描述
在这里插入图片描述
不可重复读
在这里插入图片描述
在这里插入图片描述
幻读
在这里插入图片描述
在这里插入图片描述
死锁
在这里插入图片描述
线程死锁
在这里插入图片描述
死锁产生条件:1、互斥
在这里插入图片描述
死锁产生条件:2、持有并等待
在这里插入图片描述

死锁产生条件:3、不可剥夺
在这里插入图片描述
死锁产生条件:4、循环等待
在这里插入图片描述
避免死锁
在这里插入图片描述
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

70. 爬楼梯解题思路

文章目录 题目解题思路 题目 假设你正在爬楼梯。需要 n 阶你才能到达楼顶。 每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢? 示例 1: 输入:n 2 输出:2 解释:有两种方法可以爬到楼顶。 1 阶 …

【原创】用 VisualGLM 进行AIGC多模识别和内容生成

最近几个月,整个AI行业的LLM(大语言模型)蓬勃发展,除了过去传统的纯文字的多模态能力的视觉语言模型,如 GPT-4,ImageBind等表现令人印象深刻。 ChatGLM-6B是中文用户使用非常舒服的一个开源中文LLM。2023年…

Nginx的Rewrite的运用

Rewrite 一、常用的Nginx正则表达式二、lication三、rewrite$request_uri:包含请求参数的原始URI,不包含主机名,如:http://www.kgc.com/abc/bbs/index.html?a1&b2 中的 /abc/bbs/index.php?a1&b2 $uri:这个变…

chatgpt赋能python:Python去除重复字符并排序

Python去除重复字符并排序 在日常编程工作中,我们常常需要对列表或字符串中的重复字符进行去除,并将剩余字符进行排序。Python是一门非常适合进行此类操作的语言,其内置的数据结构和函数可以让我们轻松应对这一需求。 介绍 当我们需要对一…

【六一】【海思SS528】GPIO寄存器操作 - 使能GPIO管脚输出高、低电平

目录 一、概述二、配置复用控制寄存器,使能GPIO功能三、配置GPIO_DIR寄存器,选择输出四、配置GPIO_DATA寄存器,输出高电平五、测试 一、概述 这篇文章根据海思SS528芯片提供的《22AP30 H.265编解码处理器用户指南.pdf》文档(文档路径&#xf…

MIT6.042学习笔记(一)——强归纳法,数论(1)

如果学生在学校里学习的结果是使自己什么也不会创造,那他的一生永远是模仿和抄袭。——列夫托尔斯泰 文章目录 引言强归纳法例题:拆积木游戏证明 数论(第一节)整除运算例题:取水证明 公约数例题证明 Eucild算法 引言 …

C语言-static的用法

1、static 关键字 C 语言中 static 关键字修饰变量和函数。 static有三种不同的用法: 1.修饰局部变量; 2.修饰全局变量; 3.修饰函数 局部变量:当函数第一被调用,函数中的静态局部变量被初始化,再次调用这个函数&…

gcc/g++

文章目录 sudo 提权添加白名单gcc / g预处理编译汇编链接 sudo 提权添加白名单 1.寻找root用户 在 /etc/sudoers 文件中修改 添加普通用户的白名单 :/root找到root的白名单所在行数 2.wq!强制保存退出,即可添加成功 gcc / g 推荐写法 gcc mycode.c -o mytest预…

Python绘制柱状图堆叠图

本文详细介绍如何使用 Matplotlib 绘制柱状堆叠图 文章目录 一、引入库二、数据准备三、绘制基本柱状堆叠图1.绘制基本图形2.设置柱子宽度、添加刻度标签和旋转角度 四、完整代码五、运行结果六、python绘图往期系列文章目录 一、引入库 import matplotlib.pyplot as plt imp…

Hyperledger Fabric 超级账本学习【14】Fabcar实例——通过 Nodejs命令 调用链码

文章目录 Hyperledger Fabric2.X 网络 以后对应的 Node Npm 版本需要升级,默认版本太低,后面会报错启动 Fabcar 网络报错运行以下命令来杀死当前运行或者活跃的容器:清除所有缓存网络:添加映射文件进入javascript目录在此文件夹内…

初阶数据结构(7)(树形结构的概念和相关重要定义、树的表示形式、树的应用、二叉树【两种特殊的二叉树、性质、存储、遍历、基本操作、二叉树相关的 OJ 题】)

接上次博客:初阶数据结构(6)(队列的概念、常用的队列方法、队列模拟实现【用双向链表实现、用数组实现】、双端队列 (Deque)、OJ练习【用队列实现栈、用栈实现队列】)_di-Dora的博客-CSDN博客 目录 树形结构的概念 …

DPDK官方文档说明

目录 1、Release Notes 2、Getting Started Guide for Linux/FreeBSD/Windows 3、Programmer’s Guide 4、API Reference 5、Sample Applications User Guide 6、DPDK Tools User Guides 7、Testpmd Application User Guide 8、Network Interface Controller Drivers …

网站优化,如何挖掘长尾关键词?

做网站优化来说,挖掘一些长尾关键词的重要性是非常大的,因为长尾关键词给我们带来的流量可能会超过我们的主关键词。如何挖掘长尾关键词,挖掘长尾关键词的的方式有哪些是一个重要的问题。 长尾词挖掘方式: 【1】使用长尾词挖掘工…

机器学习——线性回归、梯度下降

文章目录 一、机器学习的分类二、线型回归Linear regression(单变量线性回归)三、代价函数3.1 建模误差3.2 平方误差代价函数 Squared error cost function3.3 梯度下降3.4 梯度下降与线性回归相结合 一、机器学习的分类 监督学习:学习数据带…

生成模型之高斯判别分析(GDA)和贝叶斯

生成模型与判别模型的区别 判别模型的学习算法学习给定x下的条件分布p(y|x; θ), 例如,Logistic Regression(对数几率回归)将p(y|x; θ)建模为,g是sigmoid函数。 考虑一个分类问题,基于动物的某些特征想…

电商数据监测:如何获取想要的电商平台数据?

随着电商行业的发展,越来越多的企业开始通过电商平台销售商品。为了更好地掌握市场信息和消费者需求,企业需要获取电商平台上的数据。这些数据可以帮助企业制定营销策略、优化产品设计和提高竞争力。本文将介绍如何使用电商API获取想要的电商平台数据。 …

数据库的增删改查(一)

1、CRUD *注释:在SQL中可以使用"--空格描述"来表示注释说明 *CRUD即增加(Create)、查询(Retrieve)、更新(Update)、删除(Delete)四个单词的首字母缩写 2、新增(Create) 语法: insert [into] table_name [(column[,column] ...)…

【红队靶场】暗月五月考核靶场sunday

红队靶场 🎉B站配套视频:【顺手挂个三连呗】 https://www.bilibili.com/video/BV1xu4y1Z71y/?share_sourcecopy_web&vd_source0e30e09a4adf6f81c3038fa266588eff🔥系列专栏:红队靶场 🎉欢迎关注🔎点赞…

【MySql】ProxySQL

文章目录 ProxySQL运行机制ProxySQL安装ProxySQL的Admin管理接口和admin管理接口相关的变量admin-admin_credentialsadmin-stats_credentialsadmin-mysql_ifaces 读写分离环境信息部署步骤 负载均衡连接池自动摘除宕机的DB动态加载配置访问控制查询缓存ProxySQL 集群来源 Proxy…

送礼物 dfs 双向dfs 剪枝 java

🍑 送礼物 达达帮翰翰给女生送礼物,翰翰一共准备了 N N N 个礼物,其中第 i i i 个礼物的重量是 KaTeX parse error: Undefined control sequence: \[ at position 2: G\̲[̲i\]。 达达的力气很大,他一次可以搬动重量之和不超…