Mysql的事务

ops/2024/11/14 9:02:28/

简单来说,事务就是一组原子性的sql语句。这个语句要么全部执行要么都不执行

特性
  • 原子性:确保事务的所有操作要么全部完成要么全部不完成,事务的所有操作都视为一个单一不可分割的单元

场景:UPDATE cs_user SET age = 18 , gender = '女' WHERE id = 4。要么全部更新要么更新失败,不会出现age更新成功,

  • 一致性:保证事务从一种状态转换到另一种状态。在事务开始之前和结束之后,数据库的完整性约束没有被破坏。即使事务失败并回滚,数据库有回到一致性的状态

场景:比如规定某个表的字段age大于等于12小于18时,字段type为青少年,而数据库中存在age=16的时候,type='儿童'。会添加失败进行回滚,保存数据的一致性,约束不变

  • 持久性:确保一旦事务提交,数据的改变是永久化的,即使发生系统崩溃也不会造成数据的丢失

  • 隔离性:保证事务是彼此独立的,并发执行的事务互不干扰。不同的事务隔离级别会影响并发事务的表现。

事务的并发问题及隔离级别
并发问题

脏读(Dirty Read)

  • 一个事务读取了另一个事务尚未提交的数据。如果那个事务回滚了,那么第一个事务读取到的数据就是无效的、不一致的。

  • 如:事务A读取了事务B更新的数据,然后B回滚操作,那么A读取到的数据是脏数据

不可重复读(Non-repeatable Read)

  • 在一个事务中,两次读取同一数据却得到了不同的结果。这是因为在两次读取之间,另一事务修改了该数据并提交了。(侧重于修改)

  • 如事务 A 多次读取同一数据,事务 B 在事务A多次读取的过程中,对数据作了更新并提交,导致事务A多次读取同一数据时,结果 不一致。

幻读(Phantom Read)

  • 一个事务在读取某范围内的数据时,另一个事务在该范围内插入或删除了数据,导致该事务再次读取时,数据行数发生变化。(侧重于新增或者删除)

  • 系统管理员A将数据库中所有学生的成绩从具体分数改为ABCDE等级,但是系统管理员B就在这个时候插入了一条具体分数的记录,当系统管理员A改结束后发现还有一条记录没有改过来,就好像发生了幻觉一样,这就叫幻读。

基于此就需要有不同的事务级别来解决不同的问题,但是事务的隔离级别越高,系统的性能就越低,需要根据具体业务需要来判定

隔离级别

读未提交(Read Uncommitted)

  • 允许一个事务读取另一个事务尚未提交的数据。

  • 存在的并发问题:脏读、不可重复读、幻读。

  • 并发性最高,但数据一致性最差。

读已提交(Read Committed)

  • 只允许一个事务读取另一个事务已提交的数据。

  • 存在的并发问题:不可重复读、幻读。

  • 比未提交读更高的一致性,但仍然存在一定的数据一致性问题。

可重复读(Repeatable Read)- 默认

  • 确保在同一事务中多次读取同一数据时,数据是相同的。

  • 存在的并发问题:幻读。

  • MySQL InnoDB存储引擎的默认隔离级别,解决了脏读和不可重复读问题,但幻读仍可能发生。

序列化(Serializable)

  • 强制事务按顺序执行,完全避免了脏读、不可重复读和幻读问题。

  • 并发性最低,但数据一致性最高。

  • 在这种级别下,事务就像串行执行一样,确保完全的隔离性。

事务隔离级别脏读不可重复读幻读
读未提交(read-uncommitted)
读已提交(read-committed)
可重复读(repeatable-read)
序列号(serializable)


http://www.ppmy.cn/ops/50559.html

相关文章

【react】useState 使用指南

React的useState是函数组件中用于管理状态(state)的Hook。以下是关于useState的使用指南,结合参考文章中的信息,以清晰、分点的方式表示: 1. 基本概念 useState是React函数组件中用于管理状态(state)的Hook。它接受一个初始状态值,并返回一个包含当前状态和一个用于更新…

docker 中 File Sharing 和Volumes 的区别

在 Docker 中,File Sharing 和 Volumes 都涉及到将文件和目录从主机系统映射到容器中,但它们的用途和实现方式有一些重要的区别: 一、简介 File Sharing 是 Docker Desktop 在 Windows 和 macOS 上的一项功能,允许你将主机文件系…

Python 列表添加多个值(四种方法)

Python 列表添加多个值有多种方法,以下是其中几种实现方法: 一、使用extend()方法 Python 中列表对象有一个 extend() 方法,它可以一次性添加另一个列表中的所有元素到当前列表中。 例1: a = [1, 2, 3] b = [4, 5, 6] a.extend(b)

芜湖!恒驰大数据迁移案例荣幸亮相“东数西算”芜湖集群创新大会暨华为云华东(芜湖)数据中心全球开服活动

6月13日至14日,“东数西算”芜湖集群创新大会暨华为云华东(芜湖)数据中心全球开服活动在安徽芜湖隆重举办,标志着“东数西算”芜湖集群正式上线、华为云全国存算网的枢纽节点布局全面完成。 本次活动由华为技术有限公司主办、芜湖…

【Linux】进程间通信上 (1.5万字详解)

目录 一.进程间通信介绍 1.1进程间通信的目的 1.2初步认识进程间通信 1.3进程间通信的种类 二.匿名管道 2.1何为管道 2.1实现原理 2.3进一步探寻匿名管道 2.4编码实现匿名管道通信 2.5管道读写特点 2.6基于管道的进程池设计 三.命名管道 3.1实现原理 3.2代码实现 四.…

【Java】已解决java.util.EmptyStackException异常

文章目录 一、问题背景二、可能出错的原因三、错误代码示例四、正确代码示例五、注意事项 已解决java.util.EmptyStackException异常 一、问题背景 java.util.EmptyStackException是Java在使用java.util.Stack类时可能会遇到的一个异常。这个异常通常在尝试从空的栈中弹出&am…

写给前端同学的终端修炼手册

❝ 成功不是终点,而失败并不致命:有勇气继续下去才是最重要的。——温斯顿S丘吉尔 大家好,我是柒八九。一个专注于前端开发技术/Rust及AI应用知识分享的Coder ❝ 此篇文章所涉及到的技术有 Bash/Zsh Hyper Git Bash Amazon Q 因为&#xff0c…

CDP在企业数字化转型中扮演了什么角色?

CDP(客户数据平台)在企业数字化转型中扮演了至关重要的角色。具体来说,CDP在以下几个方面对企业数字化转型产生了深远影响: ​ 1、数据整合与标准化 CDP作为一个统一的技术平台,能够管理和整合分散的第一、第二和第…