mysql事务回滚机制概述「建议收藏」

mysql事务回滚机制概述

大家好,又见面了,我是全栈君。

应用场景:
   银行取钱,从ATM机取钱,分为以下几个步骤
       1 登陆ATM机,输入密码;
    2 连接数据库,验证密码;
    3 验证成功,获得用户信息,比如存款余额等;
    4 用户输入需要取款的金额,按下确认键;
    5 从后台数据库中减掉用户账户上的对应金额;
    6 ATM吐出钱;
    7 用户把钱拿走。
    对于上面的取钱这个事情,如果有一步出现错误的话,那么就会取消整个取钱的动作,但是如果在第5步,系统后台已经把钱减了,但是ATM机没有取出来,那么就应用到mysql中的事务。简单地
来说,就是取钱这7步要么都完成,要么就啥也不做,在数据库中就是这个道理。

    事务是用户定义的一个数据库操作序列,这些操作要么全做要么全不做,是一个不可分割的工作单位,事务回滚是指将该事务已经完成的对数据库的更新操作撤销,在事务中,每个正确的原子
操作都会被顺序执行,直到遇到错误的原子操作。回滚的意思其实即使如果之前是插入操作的话,那么会执行删除之前插入的记录,如果是修改操作的话,那么会执行将update之前的记录还原。
因此,正确的原子操作是真正被执行过的,是物理执行。

    事务是由一条或者多条sql语句组成,在事务的操作中,要么这些sql语句都执行,要么都不执行。

    事务的ACID特性:原子性,一致性,隔离性,持久性。
   
   在当前事务中确实能看到插入的记录,最后只不过被删除了,但是auto_increament不会删除而是改变值

   为什么auto_increament没有回滚:因为innodb存储引擎中的auto_increment就是主键的计数记录的当前值是保存在内存中,并不是存在磁盘中的,当mysql server处于运行的时候,这个计数值只会随着
insert增长,不会随着delete减少。而当mysql server启动的时候,当我们需要查询auto_increment计数值时,mysql便会自动执行:SELECT MIX(ID) FROM 表名 FOR UPDATE;这条语句来获得auto_increment
列的最大值,然后将这个值放到auto_increment计数器中,所以ROLLBACK MYSQL的auto_increment计数器也不会做负运算

    事务分为哪些种:扁平事务,带有保存点扁平事务,链事务,嵌套事务,分布式事务。

    MYSQL中使用事务:
  在MYSQL命令行命令下事务都是自动提交的,即执行Sql语句就会马上执行COMMIT操作。因此要显示一个事务的开启必须使用命令BEGIN或者START TRANSACTION,或者执行命令SET AUTOCOMMIT=0来
禁止当前回话的自动提交

   事务控制语句:
BEGIN/START TRANSACTION:显示地开启一个事务
COMMIT:也可以使用COMMIT WORK 两者是等价的。COMMIT会提交事务,并是已对数据库进行的所有的修改是永久性的。
ROLLBACK:也可以使用ROLLBACK WORK,两者也是等价的,回滚会结束用户的事务,并且会撤销正在进行的所有未提交的修改。
SAVEPOINT identifier:允许在事务中创建一个保存点,一个事务中可以有多个SAVEPOINT
release SAVEPOINT identifier:删除一个事务的保存点,当没有制定的保存点,会抛出一个异常。 
SET TRANSACTION:用来设置事务的隔离级别。Innodb存储引擎提供的事务隔离级别有READ UNCOMMITED,READ COMMITED,REPEATABLE READ和SERIALIZABLE.
   
    事务的隔离级别:在数据库操作中,为了保证并发读取数据的正确性,提出了隔离级别,如上
  区别如下:
  隔离级别 脏读(Dirty Read) 不可重复读(NonRepeatable Read) 幻读(Phantom Read)
  未提交读 read uncommited 可能 可能 可能
  已提交读 read commited 不可能 可能 可能
  可重复读 repeatable read 不可能 不可能 可能
  可串行化 serializable 不可能 不可能 不可能

   脏读:一个事务读取到了另一个事务没有提交的数据
例如:事务T1更新了一行记录的内容,但是并没有提交所做的修改。事务T2读取到了T1更新后的行,然后T1执行回滚操作,取消了刚才所做的修改。现在T2所读取的行就无效了

   不可重复读:在同一事务中,两次读取同一数据,得到的内容不同
例如:事务T1读取一行记录,紧接着事务T2修改了T1刚才读取的那一行记录。然后T1又再次读取这行记录,发现与刚才读取的结果不同。这就称为“不可重复”读,因为T1原来读取的那行记录已经发生了变化

   幻读:在同一事务中,用同样的操作读取两次,得到的记录数不同
例如:事务T1读取一条指定的WHERE子句所返回的结果集。然后事务T2新插入 一行记录,这行记录恰好可以满足T1所使用的查询条件中的WHERE子句的条件。然后T1又使用相同的查询再次对表进行检索,
     但是此时却看到了事务T2刚才插入的新行。这个新行就称为“幻像”,因为对T1来说这一行就像突然出现的一样
   
   隔离级别越低,事务请求的琐越少或者说是保持琐的时间越短,Innodb存储引擎默认支持的隔离界别是REPEATALE READ;在这种默认的事务隔离级别下已经能完全保证事务的隔离性。  

   mysql事务回滚怎样实现的代码可以参考此bolg:http://bbs.csdn.net/topics/390876901 

   要同时修改数据库中两个不同表时,如果它们不是一个事务的话,当第一个表修改完,可能第二个表修改过程中出现了异常而没能修改,此时就只有第二个表依旧是未修改之前的状态,
   而第一个表已经被修改完毕。而当你把它们设定为一个事务的时候,当第一个表修改完,第二表修改出现异常而没能修改,第一个表和第二个表都要回到未修改的状态,这就是所谓的事务回滚。
 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/111682.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 推荐系统在直播场景的应用(花椒直播)

    推荐系统在直播场景的应用(花椒直播)推荐系统 帮助用户发现内容 克服信息过载通过分析用户行为 对用户兴趣建模 预测用户的兴趣早期 基于热度推荐 热度高的一般质量有保证 但是集中在头部 难以千人千面现代化推荐系统全样本 生成粗排序 百万 再生成精致排序 几百个 在推荐给用户 10 量级 召回与排序 召回基于邻域的协同过滤 1 计算用户与物品的相似度矩阵 2 计算出用户对缺失物品的得分早期使用 基于主播的协同过滤由于是 n

    2026年1月22日
    1
  • aliddns ipv6_AliDDNS v2.0.0.1 – 阿里云DNS动态解析Windows客户端 支持IPv6 微信推送「建议收藏」

    aliddns ipv6_AliDDNS v2.0.0.1 – 阿里云DNS动态解析Windows客户端 支持IPv6 微信推送「建议收藏」AliDDNS使用帮助欢迎使用AliDDNS——阿里云解析DNS动态IP自动更新程序。AliDDNS通过使用阿里云API来完成DNS记录获取以及更新。AliDDNS会自动作为Windows服务在后台持续监测并更新IP地址。AliDDNS还同时支持IPv4以及IPv6,在IPv6即将普及的情况下,AliDDNS已经开启了对其的支持。AliDDNS无需安装,点击即可使用。以下为使用说明介绍:第…

    2022年6月7日
    81
  • std future get_waitkey(0)

    std future get_waitkey(0)一、关于std::future成员函数wait_for():1.1关于std::future_status:std::future_status是一个枚举类型,其值有三://ENUMfuture_statusenumclassfuture_status{//namesfortimedwaitfunctionreturnsready,timeout,deferred//延迟执行,当std::async()第一个参数为std::lanuch::de

    2025年9月28日
    4
  • ubuntu安装goland_ubuntu安装kali工具集

    ubuntu安装goland_ubuntu安装kali工具集1下载地址可以从go语言中文网下载最新的Linux包,地址如下:https://studygolang.com/dl/golang/go1.17.3.linux-amd64.tar.gzhttps://studygolang.com/dl/golang/go1.17.3.linux-amd64.tar.gz2安装进入home目录,使用wget下载子并解压,修改名字,然后创建链接(这个目的是方便后续切换golang版本的时候,只需要修改链接即可),脚本如下:cd~wgethttps

    2022年10月10日
    3
  • layui官网将于2021年10月13日下架

    layui官网将于2021年10月13日下架前言:在刚听到这个小时的时候,真的感觉很意外,从16-17年接触他一来,相对bootstrap等其他的jquey框架来说,layui算是功能最强大,社区最活跃的一款jquery框架了,至少我是这么认为的,他的功能也很强大。官方通告:官方gitee入口所有对layui为之热爱、鞭策、奉献,和支持过的开发者:请接受我用意念和字节传达的深深歉意。这是一个无力、无奈,甚至无助的决定:layui官网将于2021年10月13日进行下线。届时,包括新版下载、文档和示…

    2022年6月25日
    34
  • 虚拟机连不上网问题详解「建议收藏」

    虚拟机连不上网问题详解「建议收藏」虚拟机连不上网问题详解第一虚拟机导航栏–编辑–虚拟机网络编辑器–VMnet0桥接模式(Inter(R)Wireless—AC9462)第二虚拟机导航栏–虚拟机–设置–网络适配器–NAT模式(VMnet0)–确定第三自己windows系统–服务–确保VMware开头的五个服务全部开启,并设置成自动开启最后打开虚拟机终端输入命令(重启网络服务)servicenetworkrestart我的是出现下面状态 [root@localhost~]#servicenetw

    2022年6月26日
    23

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号