事物Transaction

事务transaction

事务:要么都完成,要么都不完成。

ACID:原子性;一致性;隔离性;持久性

 

丢失更新:

时间

取款事务A

存款事务B

T1

开始事务

 

T2

 

开始事务

 

查询余额1000

 

 

 

查询余额1000

 

 

汇入100变成1100

 

 

提交事务

 

取100余额变成900

 

 

撤销事务

 

T9

余额恢复为1000(丢失更新)

 

 

脏读:读到另一个事务还没有提交的数据。

时间

取款事务A

转账事务B

T1

开始事务

 

 

 

开始事务

 

 

查询账户1000

 

 

汇入100变为1100

 

查询余额1100

 

 

 

回滚

 

取款1100

 

T8

提交事务失败

 

 

不可重复读:前后读出的数据不一样,被另一个事务影响了。

时间

取款事务A

转账事务B

 

开始事务

 

 

 

开始事务

 

查询余额1000

 

 

 

汇入100变1100

 

 

提交事务

 

查询余额1100

 

 

提交事务

 

 

 

 

 

 

 

第二类丢失更新(不可重复读特殊情况):

时间

转账事务A

取款事务B

 

 

开始事务

 

开始事务

 

 

 

查询账户1000

 

查询账户1000

 

 

 

取100变为900

 

 

提交事务

 

汇入100

 

 

提交事务

 

 

余额改为1100(丢失更新)

 

 

幻读:插入更新的问题,插入新数据影响读的结果,和不可重复读类似。

时间

查询学生事务A

插入新学生事务B

 

开始事务

 

 

 

开始事务

 

查询学生10人

 

 

 

插入一个新生

 

查询学生11人

 

 

 

提交事务

 

提交事务

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值