事务入门(转账-1 场景引入)

1. 是什么:

事务是数据库操作最基本的单元,逻辑上一组操作,要么都成功,如果有一个失败,则所有操作都失败

2. 典型场景:银行转账

3. 特性:(ACID)

(1)原子性:要么都成功要么都失败

(2)一致性:操作之前和操作之后的总量不变

(3)隔离性:多事务操作时候事务之间不会产生影响

(4)持久性:事务提交后数据表中的数据发生变化

  

一、建表

二、搭建项目:

 jdbcTemplate 注入 dataSource:

 daoImpl 注入 jdbcTemplate: 

service 注入 daoImpl:

三、具体实现

dao 添加接口:

daoImpl 重写 interface 接口:

service 业务层调用daoImpl数据层:

 四、单元测试:

刷新数据库,查看结果:

那么,问题来了!!!

如果lucy转出100以后,突然断网或者程序出现异常,mary是无法收到钱的,会出现如下异常:

异常模拟:

解决方案:事务操作

1. 开启事务

2. 业务操作

3. 没有异常,提交事务;出现异常,事务回滚

代码示范:

项目结构:

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值