MySQL基础:事务

 💎所属专栏:MySQL  

在这里插入图片描述

 

💎1. 事务

事务是一组操作的集合,它是一个不可分割的工作单位,事务会把所有的操作作为一个整体一起向系统提交或撤销操作请求,这些操作要么同时成功,要么同时失败

例如转账的过程:张三要给李四转1000元,此时需要先查询张三的账户余额,接着进行转出,然后转入李四的账户,但是此时如果程序出现异常,就会导致张三的钱没了,但是也没有加入到李四的账户上,这时就需要用到事务

默认MySQL的事务是自动提交的,也就是说,当执行一条SQL语句,MySQL就会立即隐式的提交事务

💎2. 事务操作

一个事务的操作流程包括了,开启事务,执行事务操作,提交事务或回滚事务,对于回滚事务来说,如果程序在执行过程中出现了错误,那么此时就需要执行回滚事务

💎2.1 查看/设置事务提交方式

 在刚开始提到过,MySQL的事务默认是自动提交的,此时把 @@autocommit 设置为0,就改为了手动的

select @@autocommit;set @@autocommit = 0;select * from account;
-- 查询张三的账户
select * from account where name = '张三';
-- 张三账户余额 -1000
update account set money = money - 1000 where name = '张三';
-- 李四账户余额 + 1000
update account set money = money + 1000 where name = '李四';

该为手动之后,有与没有设置事务提交,所以尽管执行了一些SQL语句,但是表中的数据并没有被改变

💎2.2 开启事务

start transaction ;

这个和设置  @@autocommit 为0 是一样的效果

💎2.3 提交事务

通过执行 commit 提交事务之后再刷新表格,之前的操作就生效了,并且一旦提交事务之后,就不能再进行回滚事务了

💎2.4 回滚事务

回滚事务是指在事务执行过程中遇到错误、冲突或用户取消操作等情况下,撤销已执行但尚未提交的事务中所做的所有修改,以恢复数据库到事务开始之前的状态,这样做就避免了数据因部分操作成功而部分失败导致的不一致状态。

💎3. 事务的四大特性

事务的四大特性也就是ACID,分别为:

1. 原子性(Atomicity):事务是不可分割的最小操作单元,要么全部成功,要么全部失败

2.一致性(Consistency):事务完成时,必须使所有的数据都保持一致状态

3.隔离性(Isolation):数据库系统提供的隔离机制,保证事务在不受外部并发操作影响的独立环境下运行

4.持久性(Durability):事务一旦提交或回滚,它对数据库中的数据的改变就是永久的

💎4. 并发事务问题 

并发事务问题主要是指多个事务在同时操作一个数据库或是同一张表时可能出现的问题

问题描述
脏读一个事务读取到另一个事务还没有提交的数据
不可重复读一个事务先后读取同一条记录,但两次读取的数据不同
幻读一个事务按照条件查询数据时,没有对应的数据行,但是在插入数据时,又发现这一行数据已经存在,好像出现了一个幻影

来解释一下不可重复读,例如事务A和事务B同时执行,在事务A执行查询操作之后事务B执行更新操作,然后事务B提交,这时数据库中的内容就被改变了,此时再执行事务A中的查询语句,由于查询的是相同的对象,所以就会出现两次读取的数据不同 

 再来看幻读的例子,还是两个事务同时执行,此时先执行事务A中的查询语句,查询到空的数据之后,再执行事务B中的插入语句,接着提交事务,然后再执行事务A中的插入数据,但是 id = 1已经在事务B中被插入过了,就会发生冲突,此时再查询 id = 1 就会发现这条数据已经存在了,这就是幻读

 

💎5. 事务隔离级别 

隔离级别脏读不可重复读幻读
Read uncommitted
Read committed×
Repeatable Read(MySQL默认)××
Serializable×××

设置 session 和 global 的区别:

session(会话级):session参数仅在当前会话(或连接)中有效

global(全局级):global参数是全局的,意味着改变某个系统变量的值将会对所有会话都产生影响。 需要注意的是,一旦数据库服务重启,除非在配置文件(如my.cnf或my.ini)中进行了设置,否则这些全局变量的改变就会失效。

-- 查看事务的隔离级别
select @@transaction_isolation;set session transaction isolation level read uncommitted ;

 接下来同时进行两个事务,修改事务 A 的隔离级别为 read uncommitted

此时,虽然 事务 B 并没有进行提交,但是事务 A 读取到了 事务 B 还没有提交的数据,就出现了脏读的问题

接下来看Read committed

首先修改事务 A 的隔离级别为 read committed ,然后开启事务 A ,查询当前表中的原始数据,然后开启事务 B ,执行事务 B 中的语句,再次在事务A中查询,发现数据并没有被影响,当事务B提交之后再在事务A中查询到了修改之后的数据

对于这种情况,在事务A中一直查询的是同一个表,但是由于事务B的提交而查询到不同的结果,也就是之前我们提到的不可重复读问题,针对这个问题,此时再把事务隔离级别修改为Repeatable Read,也就是MySQL默认的隔离级别

修改事务A的隔离级别为repeatable read并开启事务,先查询原始的数据,然后执行事务B的语句, 再次查询,这次事务A就不受事务B提交的影响

下面来演示一下幻读的问题:

在MySQL默认的隔离级别下,开启事务A,查找 id = 3的数据并没有找到,此时在事务B中插入这条数据,由于隔离级别的作用,虽然事务B已经提交,还是无法找到id = 3的数据,但是尝试在事务A中插入 id = 3的数据却出现了错误,这就是幻读

此时把隔离级别设置为 serializable 就能解决这个问题了

 

在这里插入图片描述

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

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

相关文章

C++第四十弹---从零开始:模拟实现C++中的unordered_set与unordered_map

✨个人主页: 熬夜学编程的小林 💗系列专栏: 【C语言详解】 【数据结构详解】【C详解】 目录 1 哈希概念 2 哈希冲突 3 哈希函数 4 哈希冲突解决 4.1 闭散列 4.1.1. 线性探测 4.1.2. 二次探测 4.2 开散列 4.2.1. 开散列概念 4.2.2…

C语言一笔画迷宫

目录 开头程序程序的流程图程序游玩的效果结尾 开头 大家好&#xff0c;我叫这是我58。 程序 #define _CRT_SECURE_NO_WARNINGS 1 #include <stdio.h> #include <string.h> #include <Windows.h> void printmaze(const char strmaze[11][11]) {int ia 0;…

智慧环卫与智慧城市:以人文本的创新发展之路

智慧环卫与智慧城市&#xff1a;以人文本的创新发展之路 前言智慧环卫与智慧城市 前言 智慧环卫和智慧城市的建设是当今社会发展的重要趋势&#xff0c;它们对于提升城市管理水平、改善居民生活质量具有至关重要的意义。随着国家政策对新型城市建设的大力推动&#xff0c;智慧…

Android13 app后台无法启动Abort background activity starts from

总纲 android13 rom 开发总纲说明 目录 1.前言 2.log分析 3.代码查找分析 4.修改方法 5.编译测试 6彩蛋 1.前言 Android13 用户app后台无法启动,提示Abort background activity starts from 10111 2.log分析 08-07 21:37:36.703: W/ActivityTaskManager(440): Back…

保护网站安全,了解常见的几种网络攻击

随着互联网技术的迅猛发展&#xff0c;网站作为信息展示和交互的重要平台&#xff0c;面临着日益复杂的网络攻击威胁。从简单的口令入侵到复杂的分布式拒绝服务&#xff08;DDoS&#xff09;攻击&#xff0c;网络攻击手段层出不穷&#xff0c;给网站所有者带来了巨大的挑战。今…

完成控制器方法获取参数-@RequestParam

文章目录 1.将方法的request和response参数封装到参数数组1.SunDispatcherServlet.java1.根据方法信息&#xff0c;返回实参列表2.具体调用 2.测试 2.封装Http请求参数到参数数组1.自定义RequestParam注解2.MonsterController.java 增加参数3.SunDispatcherServlet.java1.resol…

正则表达式备查

一、常用 符号内容\将下一字符标记为特殊字符、文本、反向引用或八进制转义符。例如&#xff0c;“n”匹配字符“n”。“\n”匹配换行符。序列“\”匹配“\”&#xff0c;“(”匹配“(”。^匹配输入字符串开始的位置。如果设置了 RegExp 对象的 Multiline 属性&#xff0c;^ 还…

ARM工作模式

ARM ARM架构ARM七个工作模式寄存器异常向量表存储格式&#xff08;内存大小端&#xff09;汇编指令 ARM架构 RAM&#xff1a;随机访问存储器 ROM&#xff1a;只读访问存储器 AHB&#xff1a;先进高速总线 APB&#xff1a;先进外设总线 USB&#xff1a;统一串行总线 norflash&am…

基于Vue.js+Express的夕阳红养老院管理系统的设计与实现--附源码98650

目 录 摘要 1 绪论 1.1 研究背景 1.2 研究意义 1.3论文结构与章节安排 2 相关技术介绍 2.1 Express框架介绍 2.2 Vue.js 2.3 MySQL数据库 2.4 Node.js主要功能 3系统分析 3.1 可行性分析 3.2 系统流程分析 3.2.1 数据新增流程 3.2.2 数据修改流程 3.2.3数据删除…

AWS SAM CLI 备忘单!

安装 AWS SAM CLI brew tap aws/tap brew 安装 aws-sam-cli 验证安装 $ sam --version 升级 SAM $ brew upgrade aws-sam-cli 您需要 AWS 凭证才能在 AWS 上工作。 构建并部署简单应用程序 $ sam init→ 下载示例应用程序 $ sam build→ 构建您的应用程序 $ sam deploy --guid…

Java学习_18_Stream流

文章目录 前言一、不可变集合二、Stream流思想第一步&#xff1a;得到Stream流第二步&#xff1a;Stream流的中间方法Stream流的终结方法 总结 前言 博客仅记录个人学习进度和一些查缺补漏。 学习内容&#xff1a;BV17F411T7Ao 一、不可变集合 不可变集合就是长度和内容都不可…

希尔排序,详细解析(附图解)

1.希尔排序思路 希尔排序是一种基于插入排序的算法&#xff0c;通过将原始数据分成若干个子序列&#xff0c;然后对子序列进行插入排序&#xff0c;逐渐减小子序列的间隔&#xff0c;最后对整个序列进行一次插入排序。 1.分组直接插入排序&#xff0c;目标接近有序--------…

C语言贪吃蛇之BUG满天飞

C语言贪吃蛇之BUG满天飞 今天无意间翻到了大一用C语言写的贪吃蛇&#xff0c;竟然还标注着BUG满天飞&#xff0c;留存一下做个纪念&#xff0c;可能以后就找不到了 /* 此程序 --> 贪吃蛇3.0 Sur_流沐 当前版本&#xff1a; Bug满天飞 */ #include<stdio.h> #includ…

【补充篇】AUTOSAR多核OS介绍(下)

文章目录 前文回顾1 AUTOSAR OS1.1 AUTSOAR OS元素1.1.1 操作系统对象1.1.2 操作系统应用程序1.1.3 AUTOSAR OS裁剪类型1.1.4 AUTOSAR OS软件分区1.2 AUTOSAR OS自旋锁1.3 AUTOSAR OS核间通信1.4 AUTOSAR OS多核调度前文回顾 在上篇文章【补充篇】AUTOSAR多核OS介绍(上)中,…

OpenMax算法详解:深度学习中的高效开集识别技术

OpenMax算法详解&#xff1a;深度学习中的高效开集识别技术 在深度学习领域&#xff0c;模型的识别能力往往受限于其训练数据集的范畴。传统的分类模型&#xff0c;如卷积神经网络&#xff08;CNN&#xff09;或循环神经网络&#xff08;RNN&#xff09;&#xff0c;通常被设计…

算法5:位运算

文章目录 小试牛刀进入正题 没写代码的题&#xff0c;其链接点开都是有代码的。开始前请思考下图&#xff1a; 小试牛刀 位1的个数 class Solution { public:int hammingWeight(int n) {int res 0;while (n) {n & n - 1;res;}return res;} };比特位计数 class Solution…

关于我的生信笔记开通《知识星球》

关于知识星球 1. 为什么到现在才开通《知识星球》 从很早关注我的同学应该了解小杜的知识分享历程&#xff0c;小杜是从2021年11月底开始进入此“坑”&#xff0c;一直坚持到现在&#xff0c;马上3年了&#xff08;24年11月底到期&#xff09;。自己也从一个小青年&#xff0…

查看U盘的具体信息,分区表格式、实际容量和分区状态

查看U盘的具体信息&#xff0c;分区表格式、实际容量和分区状态 前言&#xff1a; 利用windows自带的命令行窗口就可以 1、使用命令提示符查看MBR和GPT分区类型 &#xff08;1&#xff09;按“Windows R”键&#xff0c;在弹出的运行对话框中输入“diskpart”&#xff0c;并按…

redis面试(十九)读写锁ReadLock

读写锁ReadLock 简单来说就是互斥锁和非互斥锁。多个客户端可以同事加的锁叫读锁&#xff0c;只能有一个客户端加的锁叫写锁。这个理论应该是从数据库中来的&#xff0c;放在这里也是同样的解释。 多个客户端同时加读锁&#xff0c;是不会互斥的&#xff0c;多个客户端可以同…

YOLOv8_det/seg/pose/obb推理流程

本章将介绍目标检测、实例分割、关键点检测和旋转目标检测的推理原理,基于onnx模型推理,那么首先就需要了解onnx模型的输入和输出,对输入的图片需要进行预处理的操作,对输出的结果需要进行后处理的操作,这部分内容在我的另一个专栏《YOLOv8深度剖析》中也有介绍,如果对YO…