什么是mysql事物定义_Mysql事务原理

1. 什么是数据库事务

1.1 事务的应用场景

电商平台中例如常见的下单流程,会同时操作订单表,库存表等,有时候这些操作要在一个事务里面完成。还有金融系统业务的银行转账,需要保证一个账户增加另一个账户减少,这两个动作 一定是成功或者同时失败的。

1.2 事务的定义

维基百科定义:数据库事务(简称:事务)是数据库管理系统执行过程中的一个逻辑单位,由一个有限的数据库操作序列构成。

1.3 哪些存储引擎支持数据库事务

InnoDB

1.4 事务的四大特性

原子性(Automicity)

我们对数据库的一系列操作要么都成功要么都失败,如果其中有哪一步出现就需要回滚。undo log就是实现这一操作,里面记录了数据修改之前的值(逻辑日志),一旦发现异常就可以使用undo log实现回滚

一致性(Consistency)

事务前后的操作都是合法的正确状态,例如转账,转账前和转账后金额保持一致,能量守恒状态。

隔离性 (Isolation)

多个事务操作同一张表或者同一行数据,互不干扰。

持久性 (Durability)

对数据的操作,只要提交成功了,那么结果就是永久的,不会因为系统宕机或者重启数据库导致恢复到原来的状态。其使用redo log来实现,在操作数据时候会写到内存buffer pool在记录到redo log,如果刷新到磁盘异常,重启之后就重新读取redo log的内容,写入磁盘。

原子性,隔离性,持久性,最后都是为了实现一致性。

1.5 并发带来的问题

脏读

现在有两个事务,事务A查询id=1的数据,返回 name为张三。这是事务B开启事务事务,修改id = 1的name为李四,这时候事务A中再次读取id =1的数据,得到name =李四,然而事务B并未提交事务,这时候若是B事务回滚,那么A事务得到的就是脏数据。

db2fd6bf04c7b56bc617ac747d0dfdd8.png

2. 不可重复读

同样是两个事务,事务A查询到id=1的数据,返回name为张三

,这是事务B对id =1的数据进行修改,name改成李四,然后提交事务,这时候事务A再次读id= 1的数据,此时的name也变为李四。这种在一个事务多次读取同一数据,由于其他事务修改数据造成前后不一致的问题叫做不可重复读

ead47ae18e38f45f33a814ee0fcb41ee.png

3. 幻读

事务A对age>18的数据进行查找,只发现了一条,这时候事务B插入了一条年龄等于30的数据,事务A里面又执行了一次范围查询,结果发现多处一条数据。这种在一个事务里面多次执行查询操作,由于其他事务插入数据造成的前后数据不一致的问题,被叫做幻读取

e71fce46938bec41fbe7241e15f9daac.png

不可重复读的和幻读很容易混淆,不可重复读侧重于修改,幻读侧重于新增或删除。解决不可重复读的问题只需锁住满足条件的行,解决幻读需要锁表

1.6 隔离级别及解决的问题

fdecae603fa24e8aa13bc7b110cfe1c5.png

2. 并发事务解决方案

脏读、不可重复读和幻读都是数据库读一致性问题,需要由数据库提供一定的事务隔离机制来解决。

2.1 LBCC (Lock Based Concurrency Control)

基于锁的并发控制,在读取数据的时候对数据进行锁定,不允许其他事务修改。

2.2 MVCC (Multi Version Concurrency Control)

多版本并发控制,在修改数据的时候,给它建立一个快照,后面的事务来的时候就读取这个快照。

InnoDB为每行记录除了提供ROWID外还提供了两个隐藏字段:

DB_TRX_ID,6个字节:插入或更新行的事务ID,事务编号是自动递增的(我们把它理解为创建版本号,在数据新增或者修改为新数据的时候,记录当前事务 ID)

DB_ROLL_PTR,7字节:每次对某条聚簇索引记录进行改动时,都会把旧的版本写入到undo日志中,然后这个隐藏列就相当于一个指针,可以通过它来找到该记录修改前的信息(我们把它理解为删除版本号,数据被删除或记录为旧数据的时候,记录当前事务 ID

undo log:每次对记录进行更新后,都会将旧值放在一个undo日志中,随着更新次数增多,所有版本都会被roll_point属性连接成一个链表,我们称之为版本链,版本链的头结点就是当前记录的新值。另外,每个版本中还包含生成该版本时事务id

ReadView:出现在RC和RR隔离级别下,RC下,每次读取都会生成ReadView,RR只会读取一次,它用于记录当前事务版本,活跃在系统读写的事务等

下面我们通过一个示例来了解MVCC

首先第一个事务初始化数据

begin

insert into test values('1', '张三')

insert into test values('2', '李四')

commit

复制代码

创建版本是当前事务id,删除版本为空

idname创建版本删除版本1张三1undefined

2李四1undefined

第二个事务,执行第1次查询,读取到两条原始数据,这个时候事务 ID 是 2:

begin;

select * from test (1);

复制代码

第三个事务,插入数据

begin;

insert into test values('3', '王五');

commit;

复制代码

此时的数据,多了一条王五,它的创建版本号是当前事务编号,3:

idname创建版本删除版本1张三1undefined

2李四1undefined

3王五3undefined

第二个事务执行第二次查询

begin;

select * from test (2);

复制代码

MVCC 的查找规则:只能查找创建时间小于等于当前事务 ID 的数据,和删除时间大于当前事务 ID 的行(或未删除)。

也就是不能查到在我的事务开始之后插入的数据,王五的创建 ID 大于 2,所以还是只能查到两条数据。

第四个事务删除数据,删除id =2的李四这条数据

begin;

delete from test where id =2;

commit

复制代码

此时的数据,jack的删除版本被记录为当前事务ID,4,其他数据不变

idname创建版本删除版本1张三1undefined

2李四14

3王五3undefined

在第二个事务中,执行第 3 次查询:

begin;

select * from test (3);

复制代码

查找规则:只能查找创建时间小于等于当前事务ID的数据,和删除时间大于当前事务ID的行(或未删除)。也就是,在我事务开始之后删除的数据,所以李四依然可以查出来。所以还是这两条数据。

第五个事务,执行更新操作,这个事务事务 ID 是 5:

begin;

update test set name = '赵六' where ud =1

commit

复制代码

此时的数据,更新数据的时候,旧数据的删除版本被记录为当前事务 ID 5,产生了一条新数据,创建 ID 为当前事务 ID 5:

idname创建版本删除版本1张三15

2李四14

3王五3undefined

1赵六5undefined

第二个事务,执行第 4 次查询:

begin;

select * from test (3);

复制代码

因为更新后的数据赵六创建版本大于2,代表是在事务之后增加的,查不出来。而旧数据李四的删除版本大于2,代表是在事务之后删除的,可以查出来。

通过以上演示我们能看到,通过版本号的控制,无论其他事务是插入、修改、删除,第一个事务查询到的数据都没有变化。

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

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

相关文章

学习jvm,关于MAT an internal error occurred during:Parsing heap dump from问题

写了一个死循环不断的创建对象&#xff0c;模拟内存溢出 1 package com.zuo.test1;2 3 import java.util.ArrayList;4 import java.util.List;5 6 public class Main {7 8 public static void main(String[] args) {9 List<Demo> demosnew ArrayList<…

mysql报错5_mysql5.5 启动报错:ERROR!_MySQL

bitsCN.com在FreeBSD中启动mysql时报错&#xff0c;ERROR! The server quit without updating PID file&#xff0c;通常这是可以查看数据库目录下的.err日志&#xff0c;里面会记录一些具体的错误信息&#xff0c;对排错相当有用&#xff0c;内容如下&#xff1a;110805 17:30…

MySQL安装总结

安装MySQL&#xff1a;&#xff08;以安装5.1版本为例&#xff09; 1. 双击你下载的安装程序&#xff0c;然后会进入一个‘Welecom to the Setup Wizard for MySQL Server 5.1’的图形界面&#xff01;在这里不用做任何操作&#xff0c;点击next&#xff0c;进入下一步&a…

java swing事件_第四节 Java Swing事件处理

第四节&#xff1a;事件处理一个图形界面完的成只是程序开发中起步的工作&#xff0c;因为要想让每一个组件都发挥其作用&#xff0c;就必须对所有的组件进行事件处理。那么什么是事件处理&#xff0c;所谓事件就表示一个对象发生状态变化。例如&#xff0c;每当按下一个按钮时…

jedate-开始使用一款好用的时间插件

jeDate日期控件 -&#xff08;原生JS版&#xff09;jeDate V6.5.0 是一款原生JS开发的 不依赖任何第三方库 大众化的日期控件&#xff0c;包含 多语言、设定年月&#xff08;YYYY-MM&#xff09;、日期范围限制、开始日期设定、自定义日期格式、根据不同的日期格式&#xff0c;…

zabbix的安装(一)监控os资源:内存,cpu,io,负载,带宽

一、Linux下开源监控系统简单介绍1&#xff09;cacti&#xff1a;存储数据能力强&#xff0c;报警性能差2&#xff09;nagios&#xff1a;报警性能差&#xff0c;存储数据仅有简单的一段可以判断是否在合理范围内的数据长度&#xff0c;储存在内存中。比如&#xff0c;连续采样…

linux下rpm方式安装mysql(2012-5-12)

由于感觉前几篇博客中关于linux下rpm方式安装mysql的方法问题太多&#xff0c;今天抽时间重新实践和整理了一下&#xff0c;现在拿出来和大家分享&#xff0c;希望对家有用。 系统环境&#xff1a;Rat had enterprise linux server 6.1MySQL-5.5.22-1.linux2.6.i386VMware Work…

list java语法_java基础语法 List

List的用法List包括List接口以及List接口的所有实现类。因为List接口实现了Collection接口&#xff0c;所以List接口拥有Collection接口提供的所有常用方法&#xff0c;又因为List是列表类型&#xff0c;所以List接口还提供了一些适合于自身的常用方法&#xff0c;如表1所示。表…

基础练习

口述题1.分别解释"","",""的含义。 是赋值语句 把一个值赋值给另一个值 是判断语句 判断两个值是否相等 是赋值语句 a1 等价于 aa1 2.两个变量的关系&#xff1f;n1123456n2n1 把123456赋值给变量n1,把n2赋值给n1,n1,n2共同指向123456这个地址 …

求大神解决下这个题目!做好请发到308960728@qq.com

RIP动态路由配置RIP是使用最广泛的距离向量协议&#xff0c;通过本次配置来理解RIP协议的传播、分析、挑选路由&#xff0c;来实现路由发现、路由选择、路由切换等功能&#xff0c;掌握RIP动态路由信息协议的配置方法。1.RIP配置环境与网络拓扑结构图实验设备&#xff1a;3台CI…

elastic search java_在 Java 应用程序中使用 Elasticsearch

如果您使用过 Apache Lucene 或 Apache Solr&#xff0c;就会知道它们的使用体验非常有趣。尤其在您需要扩展基于 Lucene 或 Solr 的解决方案时&#xff0c;您就会了解 Elasticsearch 项目背后的动机。Elasticsearch(构建于 Lucene 之上)在一个容易管理的包中提供了高性能的全文…

PostgreSQL增强版命令行客户端(pgcli)

效果&#xff1a; 安装&#xff1a; https://www.pgcli.com/install 官网&#xff1a; https://www.pgcli.com/ 转载于:https://www.cnblogs.com/EasonJim/p/9042418.html

网络设备的注册与初始化

2019独角兽企业重金招聘Python工程师标准>>> NIC可用之前&#xff0c;其相关联的net_device数据结构必须先初始化&#xff0c;添加到内核网络设备数据库、配置并开启。不要把注册/除名以及开启/关闭混淆是十分重要的&#xff0c;这是两种不同的概念&#xff1a; 如果…

[转]敏捷开发中编写高质量Java代码

本文转自&#xff1a;http://dev.yesky.com/103/11164603.shtml 敏捷开发的理念已经流行了很长的时间&#xff0c;在敏捷开发中的开发迭代阶段中&#xff0c;我们可以通过五个步骤&#xff0c;来有效的提高整个项目的代码质量。 Java项目开发过程中&#xff0c;由于开发人员的…

ios3怎么取消长按弹出菜单_苹果:iOS13取消3D-Touch重压改为长按只是个BUG~

原标题&#xff1a;苹果&#xff1a;iOS13取消3D-Touch重压改为长按只是个BUG~目前iOS 13中3D-Touch功能在桌面级菜单采用的是类似iPhone XR的触觉感应(Haptic touch)&#xff0c;用户只需要长按App图标即可呼出菜单&#xff0c;继续长按则会出现删除应用的抖动界面。不同于以往…

设△ABC的内角A,B,C,所对的边分别为a,b,c,且acosB-bcosA=3/5c,则tan(A-B)的最大值为

设△ABC的内角A,B,C,所对的边分别为a,b,c,且acosB-bcosA3/5c,则tan(A-B)的最大值为 转载于:https://www.cnblogs.com/Mary-Sue/p/9048289.html

BGP笔记1

1、BGP属于EGP&#xff0c;是高级DV协议&#xff0c;也被称为路径矢量协议&#xff0c;基于TCP 179端口。 2、现在使用版本BGP-4。 3、第一次做完整更新&#xff0c;以后就只增量更新 4、Autonomous Systems&#xff1a;运行同一种选路策略&#xff0c;由统一管理者管理。 1&am…

也说读书

记得当年毕业前夕&#xff0c;一位教授说&#xff1a;“希望你们毕业后&#xff0c;能坚持每年读10本书。”当时不以为然&#xff0c;区区十本&#xff0c;岂非小菜&#xff01;毕业后&#xff0c;迫于生计&#xff0c;东奔西走&#xff0c;很难静心读书&#xff0c;偶尔拿起书…

C# 巧用anchor和dock设计复杂界面(控件随着窗体大小的变化而变化)【转】

这个在做winform程序的空间编程的时候遇到过太多次了&#xff0c;自己也想留下点经验&#xff0c;搜索了一下&#xff0c;这篇文章很好很强大了&#xff0c;感谢博主“驴子的菜园”。 程序界面如上 各部分简要说明&#xff1a; 整个窗体上覆盖一个splitcontainer。 splitcontai…

mysql内链接与交叉连接_SQLServer 2008中的交叉连接与内部连接

这里是交叉连接和内部连接的最佳示例。考虑下表表&#xff1a;Teacherx------------------------x| TchrId | TeacherName |x----------|-------------x| T1 | Mary || T2 | Jim |x------------------------x表&#xff1a;Studentx-------------…