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. 没有异常,提交事务;出现异常,事务回滚
代码示范:
项目结构: