事务<查询不到同一调用方法其它事务提交的更新;解决方案
Posted 小宝鸽
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了事务<查询不到同一调用方法其它事务提交的更新;解决方案相关的知识,希望对你有一定的参考价值。
最近遇到一个很棘手的问题,至今也解释不清楚原因,不过已经找到了解决方案。
先来看看Propagation属性的值含义,@Transactional中Propagation属性有7个选项可供选择:
Propagation.MANDATORY。当前方法必须在已经定义的Transaction中运行,如果没有已定义的Transaction则抛出异常。
Propagation.NEST。如果没有已定义的Transaction,当前方法新开一个Transaction并在该Transaction中运行。如果存在已定义的Transaction,当前方法在嵌套事务(Nested Transaction)中运行 — 嵌套事务中可以定义储存点,因此可以独立于外部的Transaction而进行rollback。
Propagation.NEVER 。当前方法不应在Transaction中运行,如果存在已经定义的Transaction则抛出异常。
Propagation.NOT_SUPPORTED。当前方法不应在Transaction中运行,如果存在已经定义的Transaction,则该Transaction暂停(挂起)直至该方法运行完毕。
Propagation.REQUIRED。 默认值。当前方法必须在Transaction中运行。如果存在已经定义的Transaction,则该方法在已定义的Transaction中运行;如果不存在已经定义的Transaction,则该方法新开一个Transaction并在其中运行。
Propagation.REQUIRES_NEW。当前方法必须在新开的Transaction中运行。如果存在已经定义的Transaction,则该已定义的Transaction暂停直至新开的Transaction执行完毕。
Propagation.SUPPORTS。当前方法不需要在Transaction中运行,但如果存在已经定义的Transaction,则该方法也可以在Transaction中正常执行。
遇到的问题是这样的:
// surports 查询不到同一调用方法其它事务提交的更新。 原因未知
a() //surports
b.b();//requstd or request_new
b.c(); //surports --查询不到b方法中更新的数据
}
解决方式:
避免这种情况的方法, a()方法不被aop代理
现在只是用这种方式解决了,但是想不明白为什么要这么做,如果有哪位大神能解释清楚原因请告知一下,非常感谢!!!
以上是关于事务<查询不到同一调用方法其它事务提交的更新;解决方案的主要内容,如果未能解决你的问题,请参考以下文章
在一个java函数里更新数据库一条数据后,更新没提交马上查询这条数据,能查到更新后的数据吗?