MySQL:简述对事务的认识

server/2024/10/18 14:25:30/

浅谈对Spring事务的认识:https://xiaoer.blog.csdn.net/article/details/80849971

一、事务的特性

事务是数据库永恒不变的话题, ACID:原子性,一致性,隔离性,持久性。
(1)原子性(Atomicity):事务是一个原子操作,由一系列动作组成。事务的原子性确保动作要么全部完成,要么完全不起作用。
(2)一致性(Consistency):一旦事务完成(不管成功还是失败),系统必须确保它所建模的业务处于一致的状态,而不会是部分完成部分失败。在现实中的数据不应该被破坏。
(3)隔离性(Isolation):可能有许多事务会同时处理相同的数据,因此每个事务都应该与其他事务隔离开来,防止数据损坏。
(4)D-持久性(Durability):一旦事务完成,无论发生什么系统错误,它的结果都不应该受到影响,这样就能从任何系统崩溃中恢复过来。通常情况下,事务的结果被写到持久化存储器中。

四个特性,最重要的就是一致性。而一致性由原子性,隔离性,持久性来保证。
(1)原子性由 Undo log 保证。Undo Log 会保存每次变更之前的记录,从而在发生错误时进行回滚。
(2)隔离性由 MVCC 和 Lock 保证。
(3)持久性由 Redo Log 保证。每次真正修改数据之前,都会将记录写到 Redo Log 中,只有 Redo Log 写入成功,才会真正的写入到 B+ 树中,如果提交之前断电,就可以通过 Redo Log 恢复记录。

二、事务的隔离级别>事务的隔离级别

MySQL数据库隔离级别:未提交读(RU)、已提交读(RC)、可重复读(RR)、串行化(serializable)。每个级别都会解决不同的问题,通常是3 个问题:脏读,不可重复读,幻读。
(1)READ_UNCOMMITTED:读未提交,最低的隔离级别,允许读取尚未提交的数据变更,可能会导致脏读、幻读或不可重复读。
(2)READ_COMMITTED:读已提交,允许读取并发事务已经提交的数据,可以阻止脏读,但是幻读或不可重复读仍有可能发生
(3)REPEATABLE_READ:可重复读,对同一字段的多次读取结果都是一致的,除非数据是被本身事务自己所修改,可以阻止脏读和不可重复读,但幻读仍有可能发生
(4)SERIALIZABLE:串行化,最高的隔离级别,完全服从ACID的隔离级别,确保阻止脏读、不可重复读以及幻读,也是最慢的事务隔离级别,因为它通常是通过完全锁定事务相关的数据库表来实现的
在这里插入图片描述
注意点:关于幻读,在数据库规范里,RR 级别会导致幻读,但是,由于 Mysql 的优化,MySql 的 RR 级别不会导致幻读:

三、事务的原理剖析

1、RU 发生脏读的原因

RU 原理是对每个更新语句的行记录进行加锁,而不是对整个事务进行加锁,所以会发生脏读。而 RC 和 RR 会对整个事务加锁。

2. RC 不能重复读的原因

RC 每次执行 SQL 语句都会生成一个新的 Read View,每次读到的都是不同的。而 RR 的事务从始至终都是使用同一个 Read View。

3、RR 不会发生幻读的原因

在使用默认的 select 时,MySql 使用 MVCC 机制保证不会幻读;当然可以使用锁,在使用锁时,例如 for update(X 锁),lock in share mode(S 锁),MySql 会使用 Next-Key Lock 来保证不会发生幻读。前者称为快照读,后者称为当前读。

参考:《MYSQL:简述多版本并发控制MVCC》

4、RR 和 Serializble 的区别

RR会造成丢失更新,Serializble可以避免这种情况。

四、事务的SQL操作


http://www.ppmy.cn/server/109669.html

相关文章

Python中排序算法之冒泡排序

排序算法是将给定的数列中的数进行升序(从小到大)或者降序(从大到小)排列。冒泡排序是排序算法的一种。 1 冒泡排序的原理 1.1 基本思想 冒泡排序是将数据中较大或者较小的数据依次向右推移的一种排序技术。它的基本思想是比较…

基于django的失物招领系统的设计与实现/ 基于Python的失物招领系统的设计与实现/失物招领管理系统

失物招领系统的设计与实现 摘要:伴随着我国全面推动信息化的趋势,我国的很多行业都在朝着互联网的方向进发。结合计算机技术的失物招领系统能够很好地解决传统失物招领存在的问题,能够提高管理员管理的效率,改善服务质量。优秀的失物招领系统…

低代码技术助力移动端开发:简化开发流程,实现快速创新

在移动互联网快速发展的今天,企业和开发者面临着越来越高的需求,要求开发高质量、功能强大的移动应用,以满足用户的期待和市场的变化。然而,传统的移动端开发流程通常复杂且耗时,需要投入大量的资源和开发人员。为了应…

为什么 mysql-connector-java 只需要在 runtime 作用范围中配置

在 Java 中,访问数据库通常依赖于 JDBC(Java Database Connectivity)技术。JDBC 定义了一套标准的 API,用于与数据库进行交互。为了访问数据库,我们编写的代码需要依赖于 JDBC 接口而不是具体的数据库实现(…

深度学习100问35:如何避免梯度爆炸发生

嘿,想避免梯度爆炸这个麻烦家伙,有好多招儿呢。 首先说说权重初始化,这就好比给游戏里的角色分配初始能力值。得合理安排神经网络的权重初始化哦,不然一开始就可能出问题。可以用像 Xavier 初始化或者 He 初始化这些方法&#x…

前端速通面经八股系列(一)—— CSS篇

CSS高频面经目录 一、CSS基础1. CSS选择器及其优先级2. CSS中可继承与不可继承属性有哪些3. display的属性值及其作用4. display的block、inline和inline-block的区别5. 隐藏元素的方法有哪些6. link和import的区别7. transition和animation的区别8. display:none与visibility:…

Python中的“for循环”:探索其无限潜力

引言 for循环是任何Python程序员工具箱中的必备技能之一。无论是在处理数据时需要遍历数组,还是在编写Web应用时循环处理请求,亦或是进行复杂的算法实现,for循环都能派上大用场。通过掌握for循环的不同用法,我们可以更高效地解决…

java 读取mysql中的表并按照指定格式导出excel

在Java中读取MySQL中的数据表并将其导出到Excel文件中,你需要以下几个步骤: 连接MySQL数据库:使用JDBC驱动程序连接到MySQL数据库。执行SQL查询:获取表数据。使用Apache POI库生成Excel文件:将数据写入Excel格式。保存…