事务细节
一.isolation:返回isolation(隔离),事务的隔离级别
1.Read Uncommitted(读取未提交内容)
2.Read Committed(读取提交内容) @Transactional(isolation = Isolation.READ_COMMITTED)(只避免脏读)
3.Repeatable Read(可重读) 避免了所有问题,mysql 默认是可重复读
4.Serializable(可串行化),一万年用不到
可百度查询/修改,mysql隔离级别
二.propagation:返回propagation(传播),事务的传播行为
传播行为,(事务的传播+事务的行为);
如果有多个事务进行嵌套运行,子事务是否和大事务,共享一个事务.
transaction1{
transaction2{
transaction3{}
transaction4{}
}
}
(常用)
1.REQUIRED 如果当前方法存在一个事务,则将该方法置于同一个事物中,如果之前不存在事务,则另新开启一个事物(delete ,insert update)(一条绳上的蚂蚱,要死一起死,所有配置都遵循大蚂蚱)
(常用)
2.REQUIRES_NEW 使用REQUIRES_NEW,需要使用 JtaTransactionManager作为事务管理器。(两条线蚂蚱,你死你的和我没关系)
它会开启一个新的事务。如果一个事务已经存在,则先将这个存在的事务挂起。
3.SUPPORTS 如果当前方法存在一个事务,则将该方法置于同一个事物中,如果之前不存在事务,则进行非事务执行(select)
4.MANDATORY 如果已经存在一个事务,支持当前事务。如果没有一个活动的事务,则抛出异常。
5.NOT_SUPPORTED PROPAGATION_NOT_SUPPORTED 总是非事务地执行,并挂起任何存在的事务。使用PROPAGATION_NOT_SUPPORTED,也需要使用JtaTransactionManager作为事务管理器。
6.NEVER 总是非事务地执行,如果存在一个活动事务,则抛出异常。
7.NESTED 如果一个活动的事务存在,则运行在一个嵌套的事务中。 如果没有活动事务, 则按TransactionDefinition.PROPAGATION_REQUIRED 属性执行
三.noRollbackFor:是一个class数组[], 那些 异常事务 可以不 回滚(可以让原来默认回滚的异常不回滚) @Transactional(noRollbackFor = {(什么)Exception.class})
四.noRollbackForClassName:是一个String数组[],那些 异常事务 可以不 回滚 显示的是(String全类名)
五rollbackFor: 是个class数组[] 那些 异常事务 需要 回滚
rollbackForClassName:是Sting数组 那些 异常事务 需要 回滚 显示的是(String全类名)
注意: 异常:
运行时异常:可以不用处理,默认会回滚
编译时异常:要么try-catch 要么方法上声明throws,默认不会回滚
事务的回滚: 默认发生运行时异常,会回滚, 编译时异常不会回滚
六.readOnly :返回boolean 设置事务的只读,我只读取,不进行增删改
可以对事物优化
readOnly = true 默认是false,开启(true) 可以加快查询速度,就不会去关系事务的其他操作
六.timeout :返回int(以秒为单位) 超时,事务超出指定时长,后自动终止并且回滚
本类BooksService中调用事务只有一个事物