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

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

  1. 【Spring】Spring 事务控制

    Spring 事务控制 Spring 事务控制介绍 JavaEE 体系进行分层开发,事务控制位于业务层,Spring 提供了分层设计业务层的事务处理解决方案. Spring 的事务控制都是基于 AOP ...

  2. Spring Security控制权限

    Spring Security控制权限 1,配置过滤器 为了在项目中使用Spring Security控制权限,首先要在web.xml中配置过滤器,这样我们就可以控制对这个项目的每个请求了. < ...

  3. Spring 之 控制反转(IoC), 依赖注入(DI)和面向切面(AOP)

    关于依赖注入, 这篇博文写的非常简单易懂. https://github.com/android-cn/blog/tree/master/java/dependency-injection 此外, 博 ...

  4. 转:spring 的控制反转

    文章一,原文地址:http://blog.sina.com.cn/s/blog_63804f6f0100kfx0.html 控制反转:       IoC(Inversion of Control,控 ...

  5. 【SSH】——spring的控制反转和依赖注入

    spring是一个轻量级的容器框架,主要是为了使企业的开发变得简单.高效.无论是从大小还是开销来讲,他都可以算是轻量级的,也是非侵入性的. 下图是spring的框架示意图,说到spring,就不得不提 ...

  6. Spring的控制反转(IOC)和依赖注入(DI)具体解释

    Spring的控制反转(IOC)和依赖注入(DI)具体解释 首先介绍下(IOC)控制反转: 所谓控制反转就是应用本身不负责依赖对象的创建及维护,依赖对象的创建及维护是由外部容器负责的.这样控制器就有应 ...

  7. Spring IoC控制反转创建实例

    Spring IoC控制反转创建实例写一个配置文件beans.xml,配置文件的约束可以访问:完整链接:https://repo.spring.io/libs-release-local/org/sp ...

  8. SSM框架之Spring(5)JdbcTemplate及spring事务控制

    Spring(5)JdbcTemplate及spring事务控制 ##1.JdbcTmeplate 它是 spring 框架中提供的一个对象,是对原始 Jdbc API 对象的简单封装.spring ...

  9. spring security控制session

    spring security控制session本文给你描述在spring security中如何控制http session.包括session超时.启用并发session以及其他高级安全配置. 创 ...

随机推荐

  1. 如何用纯 CSS 创作条形图,不用任何图表库

    效果预览 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. 在线演示 https://codepen.io/zhang-ou/pen/XqzGLp 可交互视频教 ...

  2. python测试工具

    https://wiki.python.org/moin/PythonTestingToolsTaxonomy mac pip安装 https://blog.csdn.net/ywj_486/arti ...

  3. c++ 高精度 加减乘除 四则运算 代码实现

    很久以前写的啦 记得写了好久好久一直卡在特例的数据上面 想起都心塞 那时候变量和数组的取名对我来说简直是个大难题啊 完全乱来 abcdef就一路排下来 自己看的时候都搞不懂分别代表什么 好在后来英语学 ...

  4. Struts2的线程安全性

    [什么是线程安全性?] 在多线程并发访问的情况下,如果一个对象中的变量的值不会随访问的线程而变化则是线程安全的.反之则称为非线程安全的. [Servlet是线程安全的吗?] [非线程安全的] publ ...

  5. RF新手常见问题总结--(基础篇)

    1. 经常有人问这个元素找不到,一般先排除这两个地方,再自己找找A:是否等待了足够的时间让元素加载 (增加sleep xx, wait Until xxx)B:  仔细查查,这个元素是否进入到另一个f ...

  6. Codeforces 660C Hard Process【二分 Or 尺取】

    题目链接: http://codeforces.com/problemset/problem/660/C 题意: 给定0.1组成的数组,可以改变k个0使其为1,问最终可以得到的连续的1的最大长度. 分 ...

  7. Two Paths--cf14D(树的直径)

    题目链接:http://codeforces.com/problemset/problem/14/D D. Two Paths time limit per test 2 seconds memory ...

  8. POJ 1502 水 dij

    题意:给N,表示N个节点. 给半个邻接矩阵,本身到本身的距离是0,边是双向的.当两个节点之间没有直接的边连接的时候,用x表示. 问从第一个节点到其他所有节点至少花费的时间. 这题唯一的处理是处理邻接矩 ...

  9. JVM内存区域(运行时数据区)划分

    前言: 我们每天都在编写Java代码,编译,执行.很多人已经知道Java源代码文件(.java后缀)会被Java编译器编译为字节码文件(.class后缀),然后由JVM中的类加载器加载各个类的字节码文 ...

  10. 关于Java第一次实验的对课后问题自己的理解--验证码实现及其四则运算

    问题一.对于课上ppt中EnumTest所提出的的问题进行解答 将这段代码放到文件中进行运行后发现 1.对应的Size中不同元素的并不是同一个对象 2.以其中一个枚举类型s来说,不是原始数据,即他们都 ...