看了 解惑 spring 嵌套事务 [url]http://www.iteye.com/topic/35907?page=1[/url]真是受益匪浅啊。不过再测试的时候发现个问题:
[quote]
PROPAGATION_REQUIRED -- 支持当前事务,如果当前没有事务,就新建一个事务。这是最常见的选择。
PROPAGATION_SUPPORTS -- 支持当前事务,如果当前没有事务,就以非事务方式执行。
PROPAGATION_MANDATORY -- 支持当前事务,如果当前没有事务,就抛出异常。
PROPAGATION_REQUIRES_NEW -- 新建事务,如果当前存在事务,把当前事务挂起。
PROPAGATION_NOT_SUPPORTED -- 以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。
PROPAGATION_NEVER -- 以非事务方式执行,如果当前存在事务,则抛出异常。
PROPAGATION_NESTED -- 如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则进行与PROPAGATION_REQUIRED类似的操作。
前六个策略类似于EJB CMT,第七个(PROPAGATION_NESTED)是Spring所提供的一个特殊变量。
它要求事务管理器或者使用JDBC 3.0 Savepoint API提供嵌套事务行为(如Spring的DataSourceTransactionManager)
[/quote]
在执行ServiceA.methodA()的时候执行到ServiceB.methodB() 就会挂起当前事务,新建一事务。但是执行到methodC()的时候通过spring的日志我发现methodC只是使用了当前的事务,而并未新建一个事务。对于这个问题感觉比较疑惑,不知道spring的官方文档上有没有提到。我测试的spring的版本是2.03,2.07,2.52。
ServiceA {
/**
* 事务属性配置为 PROPAGATION_REQUIRED
*/
void methodA() {
ServiceB.methodB();
methodC();
}
/**
* 事务属性配置为 PROPAGATION_NEW
*/
void methodC() {
}
}
ServiceB {
/**
* 事务属性配置为 PROPAGATION_NEW
*/
void methodB() {
}
} [quote]
PROPAGATION_REQUIRED -- 支持当前事务,如果当前没有事务,就新建一个事务。这是最常见的选择。
PROPAGATION_SUPPORTS -- 支持当前事务,如果当前没有事务,就以非事务方式执行。
PROPAGATION_MANDATORY -- 支持当前事务,如果当前没有事务,就抛出异常。
PROPAGATION_REQUIRES_NEW -- 新建事务,如果当前存在事务,把当前事务挂起。
PROPAGATION_NOT_SUPPORTED -- 以非事务方式执行操作,如果当前存在事务,就把当前事务挂起。
PROPAGATION_NEVER -- 以非事务方式执行,如果当前存在事务,则抛出异常。
PROPAGATION_NESTED -- 如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则进行与PROPAGATION_REQUIRED类似的操作。
前六个策略类似于EJB CMT,第七个(PROPAGATION_NESTED)是Spring所提供的一个特殊变量。
它要求事务管理器或者使用JDBC 3.0 Savepoint API提供嵌套事务行为(如Spring的DataSourceTransactionManager)
[/quote]
在执行ServiceA.methodA()的时候执行到ServiceB.methodB() 就会挂起当前事务,新建一事务。但是执行到methodC()的时候通过spring的日志我发现methodC只是使用了当前的事务,而并未新建一个事务。对于这个问题感觉比较疑惑,不知道spring的官方文档上有没有提到。我测试的spring的版本是2.03,2.07,2.52。
Spring事务管理深入解析
本文探讨了Spring中不同事务传播级别的行为,特别是PROPAGATION_REQUIRED和PROPAGATION_NEW的区别。作者通过具体的代码示例和服务调用流程,展示了当ServiceA调用ServiceB的方法时,事务如何被挂起和新建。
1207

被折叠的 条评论
为什么被折叠?



