【MySQL】MySQL事务基础概述与隔离级别

MySQL事务基础概述与隔离级别

在数据库管理系统中,事务是一组原子性的操作,要么全部执行成功,要么全部失败。MySQL事务的四个基本特性,即ACID(原子性、一致性、隔离性、持久性),对于数据的可靠性和完整性至关重要。

一、事务概述

在数据库管理系统中,事务是一系列操作的集合,这些操作要么全部执行成功,要么全部失败。MySQL事务具有四个重要的特性,即ACID:

  • 原子性(Atomicity):事务是原子的,要么全部执行成功,要么全部失败。
  • 一致性(Consistency):事务执行前后数据库必须保持一致状态。
  • 隔离性(Isolation):事务的执行不受其他事务的影响。
  • 持久性(Durability):一旦事务提交,其结果将永久保存在数据库中。

1.1 原子性(Atomicity)

原子性保证事务的操作是原子的,要么全部执行成功,要么全部失败。如果事务中的任何一部分操作失败,整个事务将回滚,回到原始状态。

import pymysql# 连接到MySQL数据库
conn = pymysql.connect(host='your_host', user='your_user', password='your_password', database='your_database')
cursor = conn.cursor()try:# 开启事务conn.begin()# 执行一系列操作cursor.execute("INSERT INTO users (id, name, age) VALUES (1, 'Alice', 25)")cursor.execute("INSERT INTO accounts (user_id, balance) VALUES (1, 1000)")# 提交事务conn.commit()
except Exception as e:# 发生异常,回滚事务print(f"Transaction failed: {e}")conn.rollback()
finally:# 关闭数据库连接conn.close()

在这个例子中,如果第二个INSERT语句执行失败,整个事务将回滚,数据库不会保留任何更改。

1.2 一致性(Consistency)

一致性确保事务执行前后数据库保持一致状态。这意味着事务应该将数据库从一种有效状态转换为另一种有效状态。

import pymysql# 连接到MySQL数据库
conn = pymysql.connect(host='your_host', user='your_user', password='your_password', database='your_database')
cursor = conn.cursor()try:# 开启事务conn.begin()# 执行一系列操作cursor.execute("UPDATE accounts SET balance = balance - 100 WHERE user_id = 1")cursor.execute("UPDATE accounts SET balance = balance + 100 WHERE user_id = 2")# 提交事务conn.commit()
except Exception as e:# 发生异常,回滚事务print(f"Transaction failed: {e}")conn.rollback()
finally:# 关闭数据库连接conn.close()

在这个例子中,两个UPDATE语句确保了事务执行前后账户余额总和保持不变,保持了一致性。

1.3 隔离性(Isolation)

隔离性确保一个事务的执行不受其他事务的影响。这可以通过数据库的隔离级别来控制。

import pymysql# 连接到MySQL数据库
conn = pymysql.connect(host='your_host', user='your_user', password='your_password', database='your_database', autocommit=False)
cursor = conn.cursor()try:# 开启事务conn.begin()# 第一个事务中的操作cursor.execute("UPDATE accounts SET balance = balance - 50 WHERE user_id = 1")# 在另一个连接中执行另一个事务conn2 = pymysql.connect(host='your_host', user='your_user', password='your_password', database='your_database', autocommit=False)cursor2 = conn2.cursor()cursor2.execute("UPDATE accounts SET balance = balance + 50 WHERE user_id = 1")conn2.commit()conn2.close()# 提交第一个事务conn.commit()
except Exception as e:# 发生异常,回滚事务print(f"Transaction failed: {e}")conn.rollback()
finally:# 关闭数据库连接conn.close()

在这个例子中,如果数据库的隔离级别设置得当,两个事务的执行是相互独立的,一个事务的修改不会影响另一个事务。

1.4 持久性(Durability)

持久性确保一旦事务提交,其结果将永久保存在数据库中。即使系统崩溃,重启后数据库应该能够恢复到提交事务后的状态。

import pymysql# 连接到MySQL数据库
conn = pymysql.connect(host='your_host', user='your_user', password='your_password', database='your_database')
cursor = conn.cursor()try:# 开启事务conn.begin()# 执行一系列操作cursor.execute("UPDATE accounts SET balance = balance - 200 WHERE user_id = 1")# 提交事务conn.commit()# 模拟系统崩溃raise Exception("Simulating system crash")
except Exception as e:# 发生异常,回滚事务print(f"Transaction failed: {e}")conn.rollback()
finally:# 关闭数据库连接conn.close()

在这个例子中,即使发生了系统崩溃,由于事务未提交,数据库状态不会受到影响。

二. 事务隔离级别

2.1 隔离级别的概念

事务隔离级别定义了一个事务内部的操作对其他事务的可见性程度。MySQL提供了四个隔离级别,分别是READ UNCOMMITTED、READ COMMITTED、REPEATABLE READ和SERIALIZABLE。

2.2 不同隔离级别的比较

当涉及到MySQL事务的隔离级别时,有四个不同级别,每个级别在处理并发访问时采用不同的策略:

  • READ UNCOMMITTED(读未提交):这是最低的隔离级别,允许读取未提交的数据变更。在一个事务尚未提交的情况下,其他事务就可以读取到它所做的修改。这可能导致脏读(读取到了未提交的数据变更)、不可重复读(同一查询在不同时间点返回不同的结果)和幻读(同一查询在不同时间点返回不同的行数)问题。

  • READ COMMITTED(读已提交):这个级别保证一个事务提交后对其他事务可见。它解决了脏读的问题,因为只有提交的数据才会对其他事务可见。然而,它仍可能导致不可重复读和幻读问题。

  • REPEATABLE READ(可重复读):在事务执行期间保持一致性读,即一个事务在开始时读取的数据在事务结束时仍然是一致的。这解决了不可重复读的问题,但仍可能导致幻读问题。幻读是指一个事务在读取一组记录时,另一个事务插入了新的记录,导致第一个事务在后续读取时发现了未预料到的数据。

  • SERIALIZABLE(可串行化):这是最高的隔离级别,通过锁定整个表来解决幻读问题。在这个级别下,一个事务在执行时会锁定涉及的所有行,直到事务结束才释放锁。虽然解决了幻读的问题,但由于锁的粒度较大,可能导致性能下降,因为其他事务需要等待锁释放才能继续执行。

每个隔离级别都有其优缺点,选择合适的级别取决于应用程序的需求和性能要求。在设计数据库时,了解隔离级别的影响是确保数据一致性和避免并发问题的关键。

注意:在MySQL中,默认的隔离级别是REPEATABLE READ(可重复读)。当你启动一个新的事务时,MySQL会使用REPEATABLE READ作为默认的隔离级别,这确保了在事务执行期间读取的数据保持一致性,即使其他事务对同一数据进行了修改。
需要注意的是,虽然REPEATABLE READ提供了相对较高的隔离性,但仍然可能发生幻读问题。如果需要更高的隔离性,你可以在事务内部使用SET TRANSACTION ISOLATION LEVEL语句显式设置隔离级别,例如使用SERIALIZABLE。

2.3 隔离级别的设置和影响

通过以下SQL语句可以设置隔离级别:

SET TRANSACTION ISOLATION LEVEL READ COMMITTED;

不同隔离级别的选择需要根据具体业务需求和性能要求。例如,在高并发系统中,可能需要根据具体情况权衡隔离级别和性能。

三、 代码演示

通过一个简单的MySQL事务代码演示来理解隔离级别的影响。

-- 设置隔离级别为READ COMMITTED
SET TRANSACTION ISOLATION LEVEL READ COMMITTED;-- 开启事务
START TRANSACTION;-- 事务内的操作
UPDATE accounts SET balance = balance - 100 WHERE user_id = 1;
UPDATE accounts SET balance = balance + 100 WHERE user_id = 2;-- 提交事务
COMMIT;

在上述代码中,我们设置了隔离级别为READ COMMITTED,并通过事务来确保两个账户的余额操作是原子的。你可以通过修改隔离级别并观察不同级别下的执行效果。

结语

MySQL事务的理解和应用是数据库开发中不可或缺的一部分。通过深入学习事务概念和隔离级别,我们可以更好地设计和优化数据库系统,以适应不同的业务需求。在实际项目中,根据具体情况选择合适的隔离级别是保障数据一致性和性能的重要决策。

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

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

相关文章

代码随想录算法训练营day6|242.有效的字母异位词、349.两个数组的交集、202.快乐数

哈希表理论基础 建议:大家要了解哈希表的内部实现原理,哈希函数,哈希碰撞,以及常见哈希表的区别,数组,set 和map。 什么时候想到用哈希法,当我们遇到了要快速判断一个元素是否出现集合里的时…

Unity Urp 渲染管线 创建透明材质球

按照以上方式设置后就可以得到一个透明的材质球 Tips:Blending mode : alpha 和 Blending mode : additive都是完全透明效果具体差异暂时不知道

模型创建与nn.Module

一、网络模型创建步骤 二、nn.Module 下面描述了在 PyTorch 中常见的一些属性和功能,用于存储和管理神经网络模型的参数、模块、缓冲属性和钩子函数。 parameters:用于存储和管理 nn.Parameter 类的属性。nn.Parameter 是一种特殊的张量,它被…

在做题中学习(44):无重复字符的最长字串

3. 无重复字符的最长子串 - 力扣(LeetCode) 解法:同向双指针————“滑动窗口” 思路:如下图,当right进窗口后,就出现了a重复,所以在left出窗口时时,需要跳到第一个a 后面的位置&…

【QML COOK】- 004-添加动画

1. 编辑main.qml import QtQuickWindow {width: 800height: 800visible: truetitle: qsTr("Hello World")Image {id: backgroudanchors.fill: parentsource: "qrc:/Resources/Images/arrow.png"Behavior on rotation {NumberAnimation {duration: 1000}}}…

C语言-蓝桥杯算法提高VIP-产生数

题目描述 给出一个整数 n 和 k 个变换规则。 规则: 一位数可变换成另一个一位数: 规则的右部不能为零。 例如:n234。有规则(k=2): 2-> 5 3-> 6 上面的整数…

Master01节点免密钥登录其他节点

1、执行命令 ssh-keygen -t rsa,一直敲回车 2、for i in k8s-master01 k8s-node01 k8s-node02;do ssh-copy-id -i .ssh/id_rsa.pub $i;done 输入yes和对应节点密码

【CSS】首个字符占用多行,并自定义样式

效果 代码 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta name"viewport" content"widthdevice-width, initial-scale1.0" /><title>首字母大写</title><style&…

nohup - 后台执行

nohup : no hang up 语法 nohup Command [ Arg … ] [ & ]使用示例 nohup python a.py &日志将被保留在 当前文件夹下的 nohup.out 将日志放到文件&#xff0c;不输出到终端 echo hello > 1.txt在后台执行&#xff0c;并输出日志到 log1.txt 文件 nohup pytho…

【QT】计算器-模拟实现

目录 准本工作 槽函数实现 数字按键槽函数 退格槽函数 运算符 按键 槽函数 等号槽函数 初始化及计算器页面布局 整体代码 widget.h widget.cpp 准本工作 工程创建&#xff1a; 计算器模拟实现需求分析&#xff1a; 样式预览&#xff1a; &#x1f3a0;主要功能&…

uni-app如何生成骨架屏

骨架屏是页面的一个空白版本&#xff0c;通常会在页面完全渲染之前&#xff0c;通过一些灰色的区块大致勾勒出轮廓&#xff0c;待数据加载完成后&#xff0c;再替换成真实的内容。 参考效果 骨架屏作用是缓解用户等待时的焦虑情绪&#xff0c;属于用户体验优化方案。 生成骨…

【INTEL(ALTERA)】将 PHY Lite 用于并行接口Intel Agilex7 FPGA IP 时,为何无法对 PLL 进行实例化?

说明 由于英特尔 Quartus Prime Pro Edition 软件 23.1 版存在一个问题&#xff0c;在将 PHY Lite 用于并行接口Intel Agilex 7 FPGA IP 时&#xff0c;无法在顶部子组上对锁相环 &#xff08;PLL&#xff09; 进行实例化。 解决方法 要变通解决此问题&#xff0c;可以在底部…

视频剪辑方法:智能转码从视频到图片序列,高效转换攻略

在视频编辑和后期处理中&#xff0c;经常要将视频转换为图片序列&#xff0c;以便进行单独编辑或应用。下面一起来看云炫AI智剪如何批量智能转码的方法&#xff0c;高效地将视频转换为图片序列。 视频转为序列图片缩略图效果 视频转为序列图片的效果图&#xff0c;画面清晰&a…

uView test 规则校验

uView内置了一些校验规则&#xff0c;如是否手机号&#xff0c;邮箱号&#xff0c;URL等 这些规则方法&#xff0c;挂载在$u.test下面&#xff0c;如验证是否手机号&#xff1a;$u.test.mobile(13888889999)&#xff0c;如果验证通过&#xff0c;返回true&#xff0c;否则返回f…

基于WIFI指纹的室内定位算法matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 4.1WIFI指纹定位原理 4.2 指纹数据库建立 4.3定位 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 matlab2022a 3.部分核心程序 .....................................…

【SpringCloud Alibaba笔记】(4)Seata处理分布式事务

Seata 分布式事务问题 单机单库没这个问题&#xff0c;分布式之前从1: 1 -> 1:N ->N:N 分布式之后 单体应用被拆分成微服务应用&#xff0c;原来的三个模块被拆分成三个独立的应用分别使用三个独立的数据源&#xff0c;业务操作需要调用三个服务来完成。 此时每个服务…

网络调试 UDP1,开发板用动态地址-入门6

https://www.bilibili.com/video/BV1zx411d7eC?p11&vd_source109fb20ee1f39e5212cd7a443a0286c5 1, 开发板连接路由器 1.1&#xff0c;烧录无OS UDP例程 1.2&#xff0c;Mini USB连接电脑 1.3&#xff0c;开发板LAN接口连接路由器 2. Ping开发板与电脑之间通信* 2.1 根据…

浅谈归并排序:合并 K 个升序链表的归并解法

在面试中遇到了这道题&#xff1a;如何实现多个升序链表的合并。这是 LeetCode 上的一道原题&#xff0c;题目具体如下&#xff1a; 用归并实现合并 K 个升序链表 LeetCode 23. 合并K个升序链表 给你一个链表数组&#xff0c;每个链表都已经按升序排列。 请你将所有链表合并到…

【学习总结】地面路谱分析

本文仅用于记录自己的学习总结&#xff0c;包括个人理解。不保证内容严格正确。 0. 参考资料 [1] 国标GB/T 703-2005/ISO 8608:1995。[2] Bilibili 路面不平度统计特性[3] 网络参考文档. 网盘&#xff1a;https://pan.baidu.com/s/1ameuQwdOquCrk2V1PIS-Xw?pwdut9m 1. 路面…

Java集合-ArrayBlockingQueue

Java集合-ArrayBlockingQueue 特性 public class ArrayBlockingQueue<E> extends AbstractQueue<E>implements BlockingQueue<E>, java.io.Serializable {BlockingQueue&#xff1a;定义了队列的入队出队的方法 AbstractQueue&#xff1a;入队出队的基本操…