一、事务简介

事务,简短的说就是一组操作要么全部完成,要么全部不做,绝不允许只做其中的一部分操作。 比如银行转账,A账号转给B账号1000元,其中包括两个操作A-1000、B+1000,要么这两个操作全部完成,要么全部不做,决不允许只执行其中一个操作(你可以想想想如果A-1000,但是B没有+1000会有什么后果?/斜眼笑/斜眼笑)。

事务回滚,当一个事务执行过程中发生了异常、错误,则重新回到最先未开始执行的过程。比如上面那个银行转账过程,假设A-1000操作已经完成,但是在执行B+1000操作时,系统发生位置错误,这时需要回到未执行该转账操作之前的状态,即A、B原来多少钱还是多少钱,一分不能少。

事务提交,当一个事务执行过程没有发生任何异常、错误,这时我们要保存这个事务的修改。比如上面的银行转账过程,假设A-1000、B+1000操作全部完成,没有出现任何异常、错误,这时需要保存事务执行状态修改(A减少了1000元,B增加了1000元),即事务提交。

二、事务的特性(ACID)

事务具有四大特性,如下:

①、原子性(Atomicity):整体 【原子性是指事务包含的所有操作要么全部成功,要么全部失败】 ②、一致性(Consistency):数据 【事务提交后的状态合集称为一致,也就是数据库只包含事务提交的状态】 ③、隔离性(Isolation):并发 【对于任意两个并发的事务A和B,在事务A看来,B要么在A开始之前就已经结束,要么在A结束之后才开始,这样每个事务都感觉不到有其他事务在并发地执行。】 ④、持久性(Durability):结果 【持久性是指一个事务一旦提交了,就保存到硬盘上,对数据库中的数据的改变就是永久性的】

三、五大事务隔离级别

Isolation 属性一共支持五种事务设置,具体介绍如下:

隔离级别 解释
DEFAULT 使用数据库设置的隔离级别 ( 默认 ) ,由 DBA 默认的设置来决定隔离级别 .
READ_UNCOMMITTED 会出现脏读、不可重复读、幻读 ( 隔离级别最低,并发性能高 )
READ_COMMITTED 会出现不可重复读、幻读问题(锁定正在读取的行)
REPEATABLE_READ 会出幻读(锁定所读取的所有行)
SERIALIZABLE 保证所有的情况不会发生(锁表)

四、7大事务传播属性

事务 解释
PROPAGATION_REQUIRED spring默认的事务传播级别 ,如果存在一个事务,则支持当前事务。如果没有事务则开启一个新的事务。
PROPAGATION_SUPPORTS 如果存在一个事务,支持当前事务。如果没有事务,则非事务的执行。但是对于事务同步的事务管理器,PROPAGATION_SUPPORTS与不使用事务有少许不同。
PROPAGATION_MANDATORY 如果已经存在一个事务,支持当前事务。如果没有一个活动的事务,则抛出异常。
PROPAGATION_REQUIRES_NEW 总是开启一个新的事务。如果一个事务已经存在,则将这个存在的事务挂起。
PROPAGATION_NOT_SUPPORTED 总是非事务地执行,并挂起任何存在的事务。
PROPAGATION_NEVER 总是非事务地执行,如果存在一个活动事务,则抛出异常
PROPAGATION_NESTED 如果一个活动的事务存在,则运行在一个嵌套的事务中. 如果没有活动事务, 则按TransactionDefinition.PROPAGATION_REQUIRED 属性执行,当使用PROPAGATION_NESTED时,底层的数据源必须基于JDBC 3.0,并且实现者需要支持保存点事务机制

Spring五个事务隔离级别和七个事务传播行为 Spring的四种事务特性,五种隔离级别,七种传播行为