Spring嵌套事务控制

A类   callBack_test()

B类   testadd()

C类   select(),得查询到B类testadd方法中新增的数据。以及初始化一些属性

场景:A类 嵌套 B类  B类嵌套C类;都是由spring控制事务。

要求:B类testadd方法中不受spring事务控制,单独新开个事务运行,可以使C类查询的到。

问题:A类是系统底层方法,必须受事务控制。且C类必须查询到刚刚add的数据。

分析:初步分析为:Spring事务传播性导致的,从A类开启的事务,就有完结。为了避免这样的情况。最好将相关类。不要让spring控制事务。

解决:B类中testadd()方法显示开启事务。方法例如以下:

//testadd方法中数据不受事务控制(要求:是否下发成功。不影响兴许代码运行;因此要开启一个新事务)

//开启新事务,防止跟其它事务混淆

DataSourceTransactionManager transactionManager = (DataSourceTransactionManager) SpringContextFactory

.getBean("transactionManager");

DefaultTransactionDefinition def = new DefaultTransactionDefinition();

def.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRES_NEW); //事物隔离级别,开启新事务,与A类和B类不使用同一个事务。

TransactionStatus status = transactionManager.getTransaction(def); //获得事务状态

try{

**************代码逻辑****************

transactionManager.commit(status);

}catch (Exception e) {

// TODO: handle exception

transactionManager.rollback(status);

}

补充:

将B类中testadd方法配置成不让spring事务控制,testadd方法显示开启事务。手动提交。

尝试:

将B类的testadd方法增加spring事务控制中,且配置事务级别为PROPAGATION_REQUIRES_NEW,

不起作用,原因是直接把当前事务给挂起了

  • PROPAGATION_REQUIRED:假设当前没有事务,就新建一个事务,假设已经存在一个事务,就增加到这个事务中。

    这是最常见的选择。
  • PROPAGATION_SUPPORTS:支持当前事务,假设当前没有事务。就以非事务方式运行。
  • PROPAGATION_MANDATORY:使用当前的事务,假设当前没有事务,就抛出异常。
  • PROPAGATION_REQUIRES_NEW:新建事务,假设当前存在事务,把当前事务挂起。
  • PROPAGATION_NOT_SUPPORTED:以非事务方式运行操作,假设当前存在事务。就把当前事务挂起。
  • PROPAGATION_NEVER:以非事务方式运行。假设当前存在事务。则抛出异常。
  • PROPAGATION_NESTED:假设当前存在事务,则在嵌套事务内运行。假设当前没有事务,则运行与PROPAGATION_REQUIRED类似的操作

2. 备注:

疑问:怎样手动提交spring管理的事务?注:spring事务级别是PROPAGATION_REQUIRED

答案:首先在类開始部分。开启一个事务,事务的隔离级别假设是PROPAGATION_REQUIRED。手动提交事务不起作用。

事务的隔离级别须要配置成.PROPAGATION_REQUIRES_NEW。手动提交事务才干起作用。

//开启新事务,防止跟其它事务混淆

DataSourceTransactionManager transactionManager = (DataSourceTransactionManager) SpringContextFactory

.getBean("transactionManager");

DefaultTransactionDefinition def = new DefaultTransactionDefinition();

def.setPropagationBehavior(TransactionDefinition.PROPAGATION_REQUIRES_NEW); //事物隔离级别,开启新事务,与A类和B类不使用同一个事务。

TransactionStatus status = transactionManager.getTransaction(def); //获得事务状态

參考引用:http://blog.csdn.net/ziyunlong1984/article/details/7725585

http://blog.chinaunix.net/uid-10289334-id-2964925.html

http://blog.csdn.net/hy6688_/article/details/44763869

时间: 2024-10-07 00:12:50

Spring嵌套事务控制的相关文章

Spring嵌套事务

Spring 事务传播属性如下   PROPAGATION_REQUIRED--支持当前事务,如果当前没有事务,就新建一个事务.这是最常见的选择. PROPAGATION_SUPPORTS--支持当前事务,如果当前没有事务,就以非事务方式执行. PROPAGATION_MANDATORY--支持当前事务,如果当前没有事务,就抛出异常. PROPAGATION_REQUIRES_NEW--新建事务,如果当前存在事务,把当前事务挂起. PROPAGATION_NOT_SUPPORTED--以非事务方

SSH学习八 Spring框架 -- 控制反转实现Ioc

Spring的核心是控制反转(IoC)和面向切面(AOP)控制反转--Spring通过一种称作控制反转(IoC)的技术促进了低耦合.当应用了IoC,一个对象依赖的其它对象会通过被动的方式传递进来,而不是这个对象自己创建或者查找依赖对象.你可以认为IoC与JNDI相反--不是对象从容器中查找依赖,而是容器在对象初始化时不等对象请求就主动将依赖传递给它. (以上来自百度百科 http://baike.baidu.com/link?url=_egsZcZDKcHvLJtDqFTZIR3e6lH1G-p

Spring对于控制反转的误解

 原文的片段: 几位轻量级容器的作者曾骄傲地对我说:这些容器非常有用,因为它们实现了"控制反转".这样的说辞让我深感迷惑:控制反转是框架所共有的特征,如果仅仅因为使用了控制反转就认为这些轻量级容器与众不同,就好象在说"我的轿车是与众不同的,因为它有四个轮子". 问题的关键在于:它们反转了哪方面的控制?我第一次接触到的控制反转针对的是用户界面的主控权.早期的用户界面是完全由应用程序来控制的,你预先设计一系列命令,例如"输入姓名"."输

Spring Security控制权限

Spring Security控制权限 1,配置过滤器 为了在项目中使用Spring Security控制权限,首先要在web.xml中配置过滤器,这样我们就可以控制对这个项目的每个请求了. <filter>    <filter-name>springSecurityFilterChain</filter-name>    <filter-class>org.springframework.web.filter.DelegatingFilterProxy&

spring mvc控制框架的流程及原理1: 总概及源码分析

主要介绍spring mvc控制框架的流程及原理 Spring Web MVC处理请求的流程 具体执行步骤如下: 首先用户发送请求————>前端控制器,前端控制器根据请求信息(如URL)来决定选择哪一个页面控制器进行处理并把请求委托给它,即以前的控制器的控制逻辑部分:图2-1中的1.2步骤: 页面控制器接收到请求后,进行功能处理,首先需要收集和绑定请求参数到一个对象,这个对象在Spring Web MVC中叫命令对象,并进行验证,然后将命令对象委托给业务对象进行处理:处理完毕后返回一个Model

spring IOC控制反转 DI注入

<!-- 初始化 init-method="init" 销毁destroy-method="destory" --> <!--懒加载 lazy-init="true" --> <bean id="IUDao" class="dao.IUDao" scope="singleton" init-method="init" destroy-me

spring IOC控制反转和DI依赖注入

spring framework 的doc地址:https://docs.spring.io/spring/docs/current/spring-framework-reference/ spring framework 作为一个优秀的开源框架,其高扩展和高可用性毋庸置疑.这篇文章记录spring framework的控制反转. 1.什么叫控制反转:在系统开发中我们要创建一个实例常见的做法就是new 一个对象(当然也还有其他创建实例的方法,eg 反射,工厂模式),这种通过程序员手动创建实例的行

Spring理论基础-控制反转和依赖注入

序第一次了解到控制反转(Inversion of Control)这个概念,是在学习Spring框架的时候.IOC和AOP作为Spring的两大特征,自然是要去好好学学的.而依赖注入(Dependency Injection,简称DI)却使得我困惑了挺久,一直想不明白他们之间的联系.控制反转控制反转顾名思义,就是要去反转控制权,那么到底是哪些控制被反转了?在2004年 Martin fowler 大神就提出了 "哪些方面的控制被反转了?" 这个问题,他总结出是依赖对象的获得被反转了.在

spring security控制session

spring security控制session本文给你描述在spring security中如何控制http session.包括session超时.启用并发session以及其他高级安全配置. 创建session时机我们可以准确地控制什么时机创建session,有以下选项进行控制: always – 如果session不存在总是需要创建: ifRequired – 仅当需要时,创建session(默认配置): never – 框架从不创建session,但如果已经存在,会使用该session