MySQL篇(四)事务相关知识详解

news2025/4/8 20:59:41

MySQL篇(四)事务相关知识详解

  • MySQL篇(四)事务相关知识详解
    • 一、事务的特性(ACID)
      • 原子性(Atomicity)
      • 一致性(Consistency)
      • 隔离性(Isolation)
      • 持久性(Durability)
    • 二、并发事务带来的问题
      • 脏读(Dirty Read)
      • 不可重复读(Non - repeatable Read)
      • 幻读(Phantom Read)
    • 三、解决并发事务问题的方法
      • 读未提交(Read Uncommitted)
      • 读已提交(Read Committed)
      • 可重复读(Repeatable Read)
      • 串行化(Serializable)
    • 四、MySQL的默认隔离级别
    • 五、undo log和redo log的区别
      • undo log
      • redo log
    • 六、MySQL中的MVCC(多版本并发控制)

MySQL篇(四)事务相关知识详解

一、事务的特性(ACID)

原子性(Atomicity)

原子性是指事务是一个不可分割的工作单位,事务中的操作要么全部执行,要么全部不执行。比如在银行转账中,从一个账户扣款和向另一个账户存款这两个操作必须同时成功或者同时失败,不能只执行其中一个操作 ,确保了数据的完整性和一致性。

一致性(Consistency)

一致性是指事务执行前后,数据库的完整性约束没有被破坏 。例如转账前后,两个账户的总金额应该保持不变。它关注的是业务逻辑上的正确性,通过原子性、隔离性和持久性来保证。

隔离性(Isolation)

隔离性是指多个事务并发执行时,一个事务的执行不能被其他事务干扰。不同的隔离级别决定了事务之间相互干扰的程度,比如在高并发场景下,多个事务同时操作相同数据时,隔离性可以防止数据出现脏读、不可重复读、幻读等问题。

持久性(Durability)

持久性是指一个事务一旦提交,它对数据库中数据的改变就应该是永久性的,接下来的其他操作或故障不应该对其执行结果有任何影响 。例如转账成功提交事务后,即使系统崩溃,转账的结果依然存在。

二、并发事务带来的问题

脏读(Dirty Read)

一个事务读取到了另一个事务尚未提交的数据。比如事务A修改了某条记录但未提交,此时事务B读取了这条被修改但未提交的记录,如果事务A回滚,事务B读取到的数据就是无效的脏数据。

不可重复读(Non - repeatable Read)

在一个事务内多次读取同一数据时,由于其他事务对该数据进行了修改并提交,导致在本事务中多次读取的数据不一致。例如事务A读取某条记录,然后事务B修改并提交了这条记录,事务A再次读取时得到了不同的值。

幻读(Phantom Read)

在一个事务中执行查询操作,在事务执行过程中,由于其他事务插入了新的数据,当该事务再次执行相同的查询时,结果集发生了变化,就好像产生了“幻影”数据。比如事务A查询符合某条件的记录,事务B插入了符合该条件的新记录并提交,事务A再次查询时就会发现多了一些记录。

三、解决并发事务问题的方法

通过设置不同的事务隔离级别来解决并发事务问题:

读未提交(Read Uncommitted)

最低的隔离级别,允许读取未提交的数据,会导致脏读、不可重复读和幻读问题,一般很少使用。

读已提交(Read Committed)

一个事务只能读取其他事务已经提交的数据。可以避免脏读,但仍然可能出现不可重复读和幻读问题,是大多数数据库的默认隔离级别(MySQL默认不是这个 )。

可重复读(Repeatable Read)

在一个事务内的多次读取操作会返回相同的数据,即使其他事务对数据进行了修改并提交。可以避免脏读和不可重复读,但在某些情况下仍可能存在幻读问题。MySQL的默认隔离级别是可重复读,通过MVCC(多版本并发控制)机制在一定程度上解决了幻读问题。

串行化(Serializable)

最高的隔离级别,事务会按照顺序依次执行,就像单线程环境一样,能避免脏读、不可重复读和幻读的所有问题,但并发性能较差。

四、MySQL的默认隔离级别

MySQL的默认隔离级别是可重复读(Repeatable Read) 。在这种隔离级别下,MySQL通过MVCC机制来实现事务的并发控制。MVCC为每个事务维护一个一致性视图,事务在读取数据时,根据这个视图来判断数据的可见性,从而在保证数据一致性的同时提高并发性能。

五、undo log和redo log的区别

undo log

undo log主要用于事务的回滚操作。当事务执行过程中需要回滚时,undo log可以记录数据修改前的版本信息,通过这些信息将数据恢复到事务开始前的状态。同时,undo log在MVCC机制中也起到重要作用,用于构建一致性视图,提供旧版本数据的可见性判断依据。

redo log

redo log主要用于保障事务的持久性。在事务提交时,先将事务的修改操作记录到redo log中,然后再将数据真正写入磁盘。当数据库发生崩溃恢复时,可以根据redo log中的记录将数据恢复到事务提交后的状态,确保已提交事务的数据不会丢失。

六、MySQL中的MVCC(多版本并发控制)

MVCC是一种用于实现数据库并发控制的机制,它通过为数据库中的每行数据维护多个版本来实现事务的并发执行。在MySQL的InnoDB存储引擎中:

  • 实现原理:MVCC为每行数据记录多个版本,每个版本包含事务ID等信息。当事务读取数据时,根据事务的开始时间戳和数据版本的事务ID来判断数据是否可见。如果数据版本的事务ID小于当前事务的开始时间戳,那么该版本数据对当前事务可见;否则不可见。
  • 作用:MVCC可以在不使用锁(或减少锁的使用)的情况下,实现事务的并发读取,提高了数据库的并发性能,同时在可重复读隔离级别下,配合undo log有效解决了脏读、不可重复读问题,并在一定程度上缓解了幻读问题。

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

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

相关文章

React 项目使用 pdf.js 及 Elasticpdf 教程

摘要:本文章介绍如何在 React 中使用 pdf.js 及基于 pdf.js 的批注开发包 Elasticpdf。简单 5 步可完成集成部署,包括数据的云端同步,示例代码完善且简单,文末有集成代码分享。 1. 工具库介绍与 Demo 1.1 代码包结构 ElasticP…

性能测试之jmeter的基本使用

简介 Jmeter是Apache的开源项目,基于Java开发,主要用于进行压力测试。 优点:开源免费、支持多协议、轻量级、功能强大 官网:https://jmeter.apache.org/index.html 安装 安装步骤: 下载:进入jmeter的…

CAD插件实现:所有文字显示到列表、缩放、编辑——CAD-c#二次开发

当图中有大量文字,需要全部显示到一个列表时并缩放到需要的文字时,可采用插件实现,效果如下: 附部分代码如下: private void BtnSelectText_Click(object sender, EventArgs e){var doc Application.DocumentManager.…

Oracle数据库数据编程SQL<8 文本编辑器Notepad++和UltraEdit(UE)对比>

首先,用户界面方面。Notepad是开源的,界面看起来比较简洁,可能更适合喜欢轻量级工具的用户。而UltraEdit作为商业软件,界面可能更现代化,功能布局更复杂一些。不过,UltraEdit支持更多的主题和自定义选项&am…

Linux驱动开发练习案例

1 开发目标 1.1 架构图 操作系统:基于Linux5.10.10源码和STM32MP157开发板,完成tf-a(FSBL)、u-boot(SSBL)、uImage、dtbs的裁剪; 驱动层:为每个外设配置DTS并且单独封装外设驱动模块。其中电压ADC测试,采用linux内核…

Apache httpclient okhttp(1)

学习链接 Apache httpclient & okhttp(1) Apache httpclient & okhttp(2) httpcomponents-client github apache httpclient文档 apache httpclient文档详细使用 log4j日志官方文档 【Java基础】- HttpURLConnection…

微信小程序—路由

关于 app.json 中的配置 app.json 主要是对整个小程序进行一个全局的配置。 pages:在这个配置项目中,就可以配置小程序里面的页面,小程序默认显示 pages 数组中的第一个页面windows:主要配置和导航栏相关的 当然,在…

人工智能驱动的数据仓库优化:现状、挑战与未来趋势

1. 引言:数据仓库的演进与人工智能驱动优化的兴起 现代数据仓库的复杂性和规模正以前所未有的速度增长,这主要是由于数据量、种类和产生速度的急剧增加所致。传统的数据仓库技术在应对这些现代数据需求方面显得力不从心,这催生了对更先进解决…

LVS高可用负载均衡

一、项目图 二、主机规划 主机系统安装应用网络IPclientredhat 9.5无NAT192.168.72.115/24lvs-masterredhat 9.5ipvsadm,keepalivedNAT192.168.72.116/24 VIP 192.168.72.100/32lvs-backupredhat 9.5ipvsadm,keepalivedNAT192.168.72.117/24 VIP 192.168…

脑影像分析软件推荐 | JuSpace

目录 1. 软件界面 2.工具包功能简介 3.软件安装注意事项 参考文献: Dukart J, Holiga S, Rullmann M, Lanzenberger R, Hawkins PCT, Mehta MA, Hesse S, Barthel H, Sabri O, Jech R, Eickhoff SB. JuSpace: A tool for spatial correlation analyses of magne…

逛好公园的好处

逛公园和软件开发看似是两个不同的活动,但它们之间存在一些有趣的关联和相互促进的关系: 激发创造力:公园中的自然景观、多样的人群以及各种活动能为开发者带来新的灵感和创意。软件开发过程中,从公园中获得的创意可以帮助开发者设…

【网络安全】 防火墙技术

防火墙是网络安全防御的重要组成部分,它的主要任务是阻止或限制不安全的网络通信。在这篇文章中,我们将详细介绍防火墙的工作原理,类型以及如何配置和使用防火墙。我们将尽可能使用简单的语言和实例,以便于初学者理解。 一、什么…

文档的预解析

1. 预解析的核心目标 浏览器在正式解析(Parsing)HTML 前,会启动一个轻量级的 预解析器(Pre-Parser),快速扫描文档内容,实现: 提前发现并加载关键资源(如 CSS、JavaScrip…

记一次表格数据排序优化(一)--排序30000条数据有多卡

目录 需求 第一次尝试 运行环境 思路 存储 排序 触发排序操作 如何实现高效的排序 关键1 关键2 关键3 磨刀不误砍柴工 关键4 代码 效果 卡顿原因分析 原因1 原因2 第二次尝试 需求 1 我的qt程序通过表格显示30000条数据。数据来自udp,udp每隔10秒…

图形渲染中的定点数和浮点数

三种API的NDC区别 NDC全称,Normalized Device Coordinates Metal、Vulkan、OpenGL的区别如下: featureOpenGL NDCMetal NDCVulkan NDC坐标系右手左手右手z值范围[-1,1][0,1][0,1]xy视口范围[-1,1][-1,1][-1,1] GPU渲染的定点数和浮点数 定点数类型&a…

【深度学习】CNN简述

文章目录 一、卷积神经网络(CNN)二、CNN结构特性1. CNN 典型结构2. 局部连接3. 权重共享4.空间或时间上的次采样 三、理解层面 一、卷积神经网络(CNN) 卷积神经网络(Convolutional Neural Network,CNN)是一种用于处理…

强化学习课程:stanford_cs234 学习笔记(3)introduction to RL

文章目录 前言7 markov 实践7.1 markov 过程再叙7.2 markov 奖励过程 MRP(markov reward process)7.3 markov 价值函数与贝尔曼方程7.4 markov 决策过程MDP(markov decision process)的 状态价值函数7.4.1 状态价值函数7.4.2 状态…

紫檀博物馆一游与软件开发

今天去逛了中国紫檀博物馆,里边很多层展品,也有一些清代的古物,檀木,黄花梨木家具和各种摆件,馆主陈丽华女士也是发心复原、保留和弘扬中国的传统文化,和西游记唐僧扮演者迟成瑞先生一家。 每一件展品都精…

RocketMQ初认识

ProducerCustomerNameServer: Broker的注册服务发现中心BrokerServer:主要负责消息的存储、投递和查询以及服务高可用保证 RocketMQ的集群部署: 单个master的分支多个Master 模式:集群中有多个 Master 节点,彼此之间相互独立。生产者可以将消…

Chrome开发者工具实战:调试三剑客

在前端开发的世界里,Chrome开发者工具就是我们的瑞士军刀,它集成了各种强大的功能,帮助我们快速定位和解决代码中的问题。今天,就让我们一起来看看如何使用Chrome开发者工具中的“调试三剑客”:断点调试、调用栈跟踪和…