Spring:事务管理的四大特性,事务管理机制

1:认识事务

可以把一系列要执行的操作称为事务,而事务管理就是管理这些操作要么完全执行要么完全不执行(很经典的一个例子是:A要给B转钱,首先A的钱减少了,但是突然的数据库断电了,导致无法给B加钱,然后由于丢失数据,B不承认收到A的钱;在这里事务就是确保加钱和减钱两个都完全执行或完全不执行,如果加钱失败,那么不会发生减钱)。

事务管理的意义:保证数据操作的完整性。

事务管理的四大特性: - ACID - 记住

原子性:事务的整个操作是一个整体,不可以分割,要么全部成功,要么全部失败。

一致性:事务操作的前后,数据表中的数据没有变化。

隔离性:事务操作是相互隔离不受影响的。

持久性:数据一旦提交,不可改变,永久的改变数据表数据。

事务管理操作:

1、开启事务管理:开启之后,下面的sql语句并不会马上执行并把结果写到表中,而是会写到事务日志中。

start transaction;

2、回滚操作:会清掉开始事务管理之后写到事务日志中的内容,即恢复到开启事务管理之前。

3、语法:rollback; - 如果程序发生了异常,将数据恢复到没有操作之前的那个状态。

注意:回滚操作只是回退"写"的内容,对于普通的读表select语句不能回退。

4、事务提交:将sql语句的结果写到数据表中。

语法:commit: - 持久化的保存

当 commit 或 rollback 语句执行后,事务会自动关闭

2: Spring事务管理机制

Spring事务管理 由三个接口共同完成 :

1、PlatformTransactionManager 平台相关事务管理器 - 事务管理器

2、TransactionDefinition 事务定义信息 (通过配置如何进行事务管理:隔离、传播、超时、只读)

3、TransactionStatus 事务状态 (事务管理过程中,每个时间点事务 状态信息 )

事务的隔离级别

Spring:事务管理的四大特性,事务管理机制_第1张图片

事务四大特性 ACID — 隔离性引发问题 ---- 解决事务的隔离问题–隔离级别

Mysql 默认隔离级别 REPEATABLE_READ

Oracle 默认隔离级别 READ_COMMITTED

三个对象之间的关系:

用户管理事务,需要先配置事务管理方案 TransactionDefinition、 管理事务通过TransactionManager 完成,TransactionManager根据 TransactionDefinition进行事务管理,在事务运行过程中,每个时间点都可以通过获取TransactionStatus 了解事务运行状态!

举个例子:两张银行卡转账,一张卡扣钱,一张卡加钱,为了不出现一方扣钱,另一方因为故障没收到钱的情况,使用事务管理,保障扣钱和加钱这两个条件都满足,两个条件都满足交易成立,只要有一个条件不满足交易就不成立

你可能感兴趣的:(spring,java,数据库)