MySql -- 事务
目录
1.概念
2.事务的运用场景
3.事务的四大特点
4.执行事务带来的问题
4.1 脏读
4.2 不可重复度
4.3 幻读
5. MySQL中事务的隔离级别
1.概念
事务就是把若干个独立操作打包成一个整体而诞生的一种功能.
2.事务的运用场景
比如:A——>B 转账500
A的余额-500
update 账户表 set balance = balance-500 where name = "A";
B的余额+500
update 账户表 set balance = balance+500 where name= "B";
在执行这个转账操作时,可能会出现一个问题:当A转出去500时,B还没有接收到,但是机器崩了。显然这种状态不科学,但是利用 事务的原子性 可以解决这个问题.
3.事务的四大特点
1.原子性 保证为一个整体,不可再分割.
2.一致性 在事务执行前后,数据库中的数据都得是合法的。例如:转账完成后,不能够出现账户为负数的这种情况
3.持久性 事务一旦提交后,就持久化存储起来了,数据就存储在硬盘当中了。
4.隔离性 为了解决并发执行事务引起的问题(下面会单独介绍)
4.执行事务带来的问题
4.1 脏读
举例:
有一天,当老师在写代码的时候,有位同学在老师的身边的走过,然后喵了一眼老师的电脑屏幕,看到了代码中的一些内容,然后就走了,等到上课的时候,这位同学回忆自己曾经看到的代码积极回答问题,但是老师说他回答的错误,这位同学心里就想,自己明明在老师看到了这道题的代码为什么会错.原因是老师当时把代码写错了.正好让自己给看到了,等这位学生走后,老师检查出了错误并改正.
定义:
一个事物A正在对数据进行修改,在还没有提交志气啊,另外一个事物B也对同一个数据进行了读取,此时B的读取操作就被称为"脏读",阅读到的数据也被成为"脏数据".
解决方法:
为了解决脏读的问题,MySQL引进了"写操作加锁"的机制.也就是在写代码的过程中,谁也不许看我写的代码.只能等我写完代码,才能进行阅读.
但是,此时写操作和读操作无法并发执行了.,这就降低了并发程度,但是提高了数据隔离性(数据的准确性)
4.2 不可重复度
举例:
还是在这一天,老师和同学们约定好,大家都不要看我的代码,等老师讲代码传入到码云上大家再进行阅读.(这就给写进行加锁操作)
但是,这一天老师上传了码云版本1的代码,同学们正在积极的阅读中,此时唰的一下,代码发生了改变,同学们老师原因,原来在同学们阅读代码的时候,老师将自己版本2的代码上传到了码云,使得代码发生了改变.这个过程就发生了,不可重复读.
定义:
事务1已经提交了数据,此时事务2开始读取数据,在读取的过程中,事务3又提交了新的数据.此时意味着同一个事物2之内,多次读出来的数据是不一样的.
解决方法:
为了解决这个问题,引进了"给读加锁"的机制,也就是在同学们进行阅读的时候,老师不可以再上传代码,
通过给读加锁这个机制,又进一步降低了事务并发处理能力,提高了事务的隔离性(数据的准确性又得到了提高).
4.3 幻读
举例:
当前约定好读操作和写操作进行加锁,解决了脏读和不可重复读的问题.
由于约定了读加锁,同学读的时候,老师不能进行修改代码了,只能干等着,所以老师想了一个办法,同学们读Java1文件的时候,老师修改Java2文件,但是个别情况下,有的学生不能接受,因为一开始没有Java2文件,突然冒出来一个Java2文件,无法接收.
定义:
在读操作和写操作加锁的情况下,一个事物读取同一个数据,得到的数据值是一样的,但是结果集不一样.这就称为幻读.
解决方法:
数据库使用"串行化"这样的方式来解决幻读,彻底放弃并发处理事务,一个接一个的串行的处理事务.
这样做,并发程度是最低的但是隔离性确实最高的,数据也是最准确的.
5. MySQL中事务的隔离级别

相关文章:
MySql -- 事务
目录 1.概念 2.事务的运用场景 3.事务的四大特点 4.执行事务带来的问题 4.1 脏读 4.2 不可重复度 4.3 幻读 5. MySQL中事务的隔离级别 1.概念 事务就是把若干个独立操作打包成一个整体而诞生的一种功能. 2.事务的运用场景 比如:A——>B 转账500 A的余额-500…...
关于大模型对未来影响的一点看法
人们总是高估了未来一到两年的变化,低估了未来十年的变革。 ---比尔盖茨 近来OpenAI的GPT技术可以说在全球都带来了巨大的影响,也让大家看到了什么叫大力出奇迹。chatGPT和GPT4的能力给了大家很大的震撼,其流畅自如、逻辑清晰、出众的能力&am…...
Android - 约束布局 ConstraintLayout
一、概念 解决布局嵌套过多的问题,采用方向约束的方式对控件进行定位。 二、位置约束 2.1 位置 至少要保证水平和垂直方向都至少有一个约束才能确定控件的位置。 layout_constraintLeft_toLeftOf我的左边,与XXX左边对齐。layout_constraintLeft_toRight…...
Addictive Multiplicative in NN
特征交叉是特征工程中的重要环节,在以表格型(或结构化)数据为输入的建模中起到了很关键的作用。 特征交互的作用,一是尽可能挖掘对目标有效的模式、特征,二是具有较好的可解释性,三是能够将对数据的洞见引…...
LeetCode 1206. 实现跳表
不使用任何库函数,设计一个跳表。 跳表是在 O(log(n)) 时间内完成增加、删除、搜索操作的数据结构。跳表相比于树堆与红黑树,其功能与性能相当,并且跳表的代码长度相较下更短,其设计思想与链表相似。 例如,一个跳表包…...
离散数学_九章:关系(2)
9.2 n元关系及其应用 1、n元关系,关系的域,关系的阶2、数据库和关系 1. 数据库 2. 主键 3. 复合主键 3、n元关系的运算 1. 选择运算 (Select) 2. 投影运算 (Project) 3. 连接运算 (Join) n元关系:两个以上集合的元素间的关系 1、n元关系…...
[ubuntu][原创]通过apt方式去安装libnccl库
ubuntu18.04版本安装流程: wget https://developer.download.nvidia.com/compute/cuda/repos/ubuntu1804/x86_64/cuda-ubuntu1804.pin sudo mv cuda-ubuntu1804.pin /etc/apt/preferences.d/cuda-repository-pin-600 sudo apt-key adv --fetch-keys https://develo…...
YonLinker连接集成平台构建新一代产业互联根基
近日,由用友公司主办的“2023用友BIP技术大会“在用友产业园(北京)盛大召开,用友介绍了更懂企业业务的用友BIP-iuap平台,并发布了全面数智化能力体系,助力企业升级数智化底座,加强加速数智化推进…...
泛型的详解
泛型的理解和好处 首先我们先来看看泛型的好处 1)编译时,检查添加元素的类型,提高了安全性 2)减少了类型转换的次数,提高效率[说明] 不使用泛型 Dog -> Object -> Dog//放入到ArrayList 会先转成Object,在取出时&#x…...
用科技创造未来!流辰信息技术助您实现高效办公
随着社会的迅猛发展,科技的力量无处不见。它正在悄悄地改变整个社会,让人类变得进步和文明,让生活变得便捷和高效。在办公自动化强劲发展的今天,流辰信息技术让通信业、电网、汽车、物流等领域的企业实现了高效办公,数…...
基于R语言APSIM模型
随着数字农业和智慧农业的发展,基于过程的农业生产系统模型在模拟作物对气候变化的响应与适应、农田管理优化、作物品种和株型筛选、农田固碳和温室气体排放等领域扮演着越来越重要的作用。 APSIM (Agricultural Production Systems sIMulator)模型是世界知名的作物…...
块状链表实现BigString大字符串操作(golang)
前言 块状链表是介于链表和数组之间的数据结构,能够在 O ( n ) O(\sqrt{n}) O(n )时间内完成插入、删除、访问操作。 数据结构如图所示。假设最大容量为 n n n, 则它有一个长度为 s n s\sqrt{n} sn 的链表。链表中每个结点是一个长度为 2 n 2 \times \sqrt{…...
项目问题记录(持续更新)
1.在 yarn install的时候报 error achrinza/node-ipc9.2.2: The engine "node" is incompatible with this module. Expected version "8 || 10 || 12 || 14 || 16 || 17". Got "20.1.0" error Found incompatible module.需要执行 yarn config…...
Linux的进程
目录 一、进程占用的内存资源 二、进程的系统环境 三、进程一直在切换 四、父进程和子进程 五、进程状态 六、查看进程 1.ps -ef 列出所有进程 2.ps -lax 列出所有进程 3.ps aux列出所有进程 4.树形列出所有进程 七、作业(用来查看管理进程) …...
与其焦虑被 AI 取代或猜测前端是否已死, 不如看看 vertical-align 扎实你的基础!!!
与其焦虑被 AI 取代或猜测前端是否已死, 不如看看 vertical-align 扎实你的基础!!! vertical-align 设置 display 值为 inline, inline-block 和 table-cell 的元素竖直对齐方式. 从 line-height: normal 究竟是多高说起 我们先来看一段代码, 分析一下为什么第二行的行高, 也就…...
路由、交换机、集线器、DNS服务器、广域网/局域网、端口、MTU
前言:网络名词术语解析(自行阅读扫盲),推荐大家去读户根勤的《网络是怎样连接的》 路由(route): 数据包从源地址到目的地址所经过的路径,由一系列路由节点组成。某个路由节点为数据包选择投递方向的选路过程。 路由器工作原理 路…...
在全志V851S开发板上进行屏幕触摸适配
1.修改屏幕驱动 从ft6236 (删掉,不要保留),改为下面的 路径:/home/wells/tina-v853-open/tina-v853-open/device/config/chips/v851s/configs/lizard/board.dts(注意路径,要设置为自己的实际路…...
字符串拷贝时的内存重叠问题
字符串拷贝时的内存重叠问题 1.什么是内存重叠 拷贝的目的地址在源地址的范围内,有重叠。 如在写程序的过程中,我们用到的strcpy这个拷贝函数,在这个函数中我们定义一个目的地址,一个源地址,在拷贝的过程中如果内存重…...
告别PPT手残党!这6款AI神器,让你秒变PPT王者!
如果你是一个PPT手残党,每每制作PPT总是让你焦头烂额,那么你一定需要这篇幽默拉风的推广文案! 我向你保证,这篇文案将帮助你发现6款AI自动生成PPT的神器,让你告别PPT手残党的身份,成为一名PPT王者。 无论…...
JVM配置与优化
参考: JVM内存分区及作用(JDK8) https://blog.csdn.net/BigBug_500/article/details/104734957 java 进程占用系统内存过高分析 https://blog.csdn.net/fxh13579/article/details/104754340 Java之jvm和线程的内存 https://blog.csdn.ne…...
使用FCM进行编码解码
文章目录1 FCM到底是什么?2 为什么论文里要用FCM?3 FCM输出的两个核心结果是什么?1. prototype / cluster centers2. membership matrix4 FCM到底在优化什么?5 FCM是怎么一步一步算出来的?第一步:先定簇数 c第二步:初始化隶属度矩阵第三步ÿ…...
IPv6
第一部分:为什么要有IPv6?(先解决“IPv4是什么”) 想象一下,全世界的电脑、手机、服务器要互相通信,就像寄信需要门牌号。这个门牌号在互联网里叫 IP地址。 IPv4:就是使用了30多年的老门牌号系…...
别再死记硬背了!一张图帮你搞懂SRv6里那些‘End.X’、‘End.DT4’指令到底在干啥
SRv6指令集深度解析:从快递分拣到网络封装的实战指南 每次看到SRv6里那些像密码一样的End.X、End.DT4指令,是不是感觉脑袋嗡嗡作响?别担心,今天我们不搞术语轰炸,换个视角把这些抽象指令变成你日常生活中的熟悉场景。想…...
深入PyTorch源码:图解LayerNorm两种实现,弄懂weight/bias到底怎么来的
深入PyTorch源码:图解LayerNorm两种实现,弄懂weight/bias到底怎么来的 在深度学习模型的训练过程中,归一化技术扮演着至关重要的角色。不同于BatchNorm对批处理数据的标准化处理,LayerNorm(层归一化)因其在…...
如何轻松创建虚拟游戏控制器:vJoy完整使用指南 [特殊字符]
如何轻松创建虚拟游戏控制器:vJoy完整使用指南 🎮 【免费下载链接】vJoy Virtual Joystick 项目地址: https://gitcode.com/gh_mirrors/vj/vJoy 想要在Windows电脑上创建虚拟游戏控制器吗?vJoy虚拟摇杆工具就是你的终极解决方案&#…...
告别数据丢失!用AT24C512大容量EEPROM为你的STM32项目做个可靠的数据保险箱
告别数据丢失!用AT24C512大容量EEPROM为你的STM32项目做个可靠的数据保险箱 在嵌入式开发中,数据丢失是个让人头疼的问题。想象一下,设备突然断电,所有运行参数和用户设置瞬间归零——这种场景对任何产品都是灾难性的。而AT24C512…...
别再让测试时间拖后腿!聊聊DFT工程师如何用Synopsys DFTMAX压缩Scan Chain(附实战思路)
芯片测试效率革命:DFTMAX压缩技术实战解析 在数字IC设计领域,测试时间成本已成为制约产品上市速度的关键瓶颈。当芯片规模突破亿门级时,传统扫描链架构面临的测试时间线性增长问题变得尤为突出。一位资深DFT工程师曾分享:"我…...
GESP2023年9月认证C++三级( 第一部分选择题(1-8))
🏰 第1题 App是什么?题目: 手机上安装的 App 通常指的是( )A. 操作系统 B. 应用软件 C. 通话设备 D. 都不对✅答案:B1、🌟故事时间你有一部手机📱,手机里有:微…...
HUNYUAN-MT 7B翻译终端Java八股文学习助手:技术文档中英互译与解析
HUNYUAN-MT 7B翻译终端Java八股文学习助手:技术文档中英互译与解析 1. 引言:当Java八股文遇上AI翻译 学Java的朋友,尤其是准备面试的,肯定对“八股文”这个词不陌生。它指的就是那些面试里翻来覆去问的基础知识、核心原理和经典…...
玄机靶场-2025数字中国 数据安全-溯源与取证 WP
玄机靶场-2025数字中国 数据安全-溯源与取证 WP 这道题是 2025 数字中国创新大赛数据安全赛道的原题,搬到玄机靶场上来了。主要考察磁盘数据恢复、加密驱动器解密和 Web 日志分析三块,题目一共 3 个步骤,难度中等,下面是完整解题过…...
