分为编程式事务管理和声明式事务管理
- 编程式事务管理:
* 代码中调用beginTransaction()、commit()、rollback()等事务管理相关的方法,通过TransactionTempalte手动管理事务(用的少)
- 声明式事务管理:
* 通过AOP实现,可配置文件方式或者注解方式实现事务的管理控制(用的多)
声明式事务管理本质:
本质是对方法前后进行拦截,底层是建立在 AOP 的基础之上,在目标方法开始之前创建或者加入一个事务,在执行完目标方法之后根据执行情况提交或者回滚事务
传播属性:
- 如果在开始当前事务之前,一个事务上下文已经存在,此时有若干选项可以指定一个事务性方法的执行行为
- @Transactional(propagation=Propagation.NESTED) 如果当前存在事务,则创建一个事务作为当前事务的嵌套事务来运行; 如果当前没有事务,则该取值等价于Propagation.REQUIRED。
- @Transactional(propagation=Propagation.SUPPORTS) 如果其他bean调用这个方法,在其他bean中声明事务,那就用事务.如果其他bean没有声明事务,那就不用事务.
- @Transactional(propagation=Propagation.NEVER) 必须在一个没有的事务中执行,否则抛出异常(与Propagation.MANDATORY相反)
- @Transactional(propagation=Propagation.MANDATORY) 必须在一个已有的事务中执行,否则抛出异常
- @Transactional(propagation=Propagation.REQUIRES_NEW) 不管是否存在事务,都创建一个新的事务,原来的挂起,新的执行完毕,继续执行老的事务
- @Transactional(propagation=Propagation.NOT_SUPPORTED) 不为这个方法开启事务
- @Transactional(propagation=Propagation.REQUIRED) 如果有事务, 那么加入事务, 没有的话新建一个(默认情况下)
-
事务隔离级别: 是指若干个并发的事务之间的隔离程度
- @Transactional(isolation = Isolation.READ_UNCOMMITTED) 读取未提交数据(会出现脏读, 不可重复读) 基本不使用
- @Transactional(isolation = Isolation.READ_COMMITTED) 读取已提交数据(会出现不可重复读和幻读)
- @Transactional(isolation = Isolation.REPEATABLE_READ) 可重复读(会出现幻读)
- @Transactional(isolation = Isolation.SERIALIZABLE) 串行化
- MYSQL: 默认为REPEATABLE_READ级别
@Transactional有5个属性:Propagation、Isolation、Rollback Rules、Timeout和Read-Only,
Rollback Rules : 设置出现哪些异常,则进行回滚
spring @Transactional注解参数详解 - Roy-Xin - 博客园
-
多表操作,通过@Transactional控制事务
- 启动类加注解 @EnableTransactionManagement
- 业务类 加 @Transactional