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

项目结构:

本文详细介绍了数据库操作中的事务概念,包括其基本定义、ACID特性、典型应用场景如银行转账,并通过实例讲解了如何在项目中使用事务来确保数据的一致性和安全性。
4万+

被折叠的 条评论
为什么被折叠?



