事务的回滚

事务

概念

例如:在关系数据库中,一个事务可以是一条SQL语句,一组SQL语句或整个程序。

特性

事务是恢复和并发控制的基本单位。

事务应该具有4个属性:原子性、一致性、隔离性、持久性。这四个属性通常称为ACID特性

原子性(atomicity)。一个事务是一个不可分割的工作单位,事务中包括的操作要么都做,要么都不做。

一致性(consistency)。事务必须是使数据库从一个一致性状态变到另一个一致性状态。一致性与原子性是密切相关的。

隔离性(isolation)。一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰。

持久性(durability)。持久性也称永久性(permanence),指一个事务一旦提交,它对数据库中数据的改变就应该是永久性的。接下来的其他操作或故障不应该对其有任何

回滚

回滚(Rollback)指的是程序或数据处理错误,将程序或数据恢复到上一次正确状态的行为。回滚包括程序回滚和数据回滚等类型。

转账主要根据update语句进行更新数据库。

张三转给李四200元(中间没出现故障)(没配置事务时):

张三转给李四200元(中间出现故障)(没配置事务时):

张三转给李四200元(中间出现故障)(配置了事务时):

张三转账200,李四收到200,但之间出现了一些故障,导致李四收不到200元。

因此数据库的状态必须回到没有执行的update语句之前,需要进行回滚操作,回滚就是执行一遍相反的操作,此时再执行张三的update金额加200元回到2000元。

1.张三向李四转200元,张三账户由2000元变成1800元

2.李四收到200元之前产生故障

3.出故障,要回滚

4.要回滚

5.回滚:张三转出的-200元要回滚回来,故+200元进行回滚,张三和李四的账户金额不变。张三:2000元,李四:3000元

6.即回到步骤1之前,一切不变。即:  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值