本文主要介绍:Spring事务的特性、隔离级别、传播特性
一、Spring的事务四大特性:
1、原子性:强调事务的不可分割.;
2、一致性:事务执行前后数据的完整性保持不变(事务执行前,A和B的总钱数为500,进行转账操作后,A和B的总钱数还应该是500);
3、隔离性:不同事务之间是相互独立的;
4、持久性:事务一旦执行提交操作就会持久化到数据库中。
二、Spring的事务隔离级别:
有4大隔离级别,分别是:读未提交(read uncommited)、读已提交(read commited)、可重复读(repeatable read)、串行化(serializable),隔离级别一次递增。
注:Mysql默认为可重复读(repeatable read)
oracle默认为读已提交(read commited)
1、读未提交(read uncommited):会出现脏读(脏读:事务A执行了修改还未提交、事务B读取到了这条记录,但事务A又执行了回滚,事务B就出现了脏读);
2、读已提交(read commited):可以防止脏读,但在事务A两次读取的过程中,事务B修改了这条记录并提交,就会早成事务A两次读取的结果不一致的情况,称为不可重复读(两次读取的结果不一样,重复读就可以发现);
3、可重复读(repeatable read):可以防止脏读、不可重复读的问题,但是当事务A第一次读取记录后,事务B 执行修改操作并提交,事务A第二次读取时,会读取到事务B提交的记录,造成事务A两次读到的结果不一致,就会出现幻读的问题;
4、串行化(serializable):事务执行时,会在所有级别上加锁,仿佛事务就是以串行的方式执行的,可以防止脏读、不可重复读、幻读的问题、但是会带来性能的下降。
三、Sprong的传播特性:

1、PROPAGATION_REQUIRED:支持当前事务,若当前存在事务,则支持当前事务,若不存在,则另开启新的事务;
 2、PROPAGATION_SUPPORTS:支持当前事务,若当前存在事务,则支持当前事务,若不存在,则以无事务的状态执行;
 3、PROPAGATION_MANDATORY:支持当前事务,若当前存在事务,则支持当前事务,若不存在,则抛出异常;
 4、PROPAGATION_REQUIRES_NEW:新开事务执行,若当前存在事务,则挂起当前事务;
 5:PROPAGATION_NOT_SUPPORTED:以无事务状态执行,若存在事务则挂起;
 6:PROPAGATION_NEVER:以非事务状态执行,若存在事务则抛异常;
 7、PROPAGATION_NESTED:当前存在事务,则嵌套一个新事务,当前不存在事务,则新开事务。