我的问题与here基本相同,但我对答案不满意所以我正在写这个问题。
在Spring Framework手册中声明,对于PROPAGATION_REQUIRES_NEW,当前事务将被暂停。这是如何实际实现的?我知道大多数数据库不支持嵌套事务,并且只能在一个连接中运行一个事务。这意味着您不能只是“不使用”原始事务并启动新事务 - 在启动新事务之前,您必须提交或回滚原始事务。
实施例:
START TRANSACTION
SELECT ...
UPDATE ...
-- Now we run method with PROPAGATION_REQUIRES_NEW
-- How do we "suspend" transaction so we can start new one?
START TRANSACTION
UPDATE ...
COMMIT
-- We returned from the method, result was commited
-- Now we'd like to "unsuspend" the original transaction so it can be commited/rollbacked, but how?
或者这可能是使用另一个连接(Session对象)实现的?那么我们就停止使用原始连接并创建一个新的连接,我们可以开始新的交易了吗?
我在这里遗漏了一些显而易见的事情,没有人愿意解释它(至少在Spring文档,Spring in Action,Spring持久化Hibernate中)。
非常感谢!
答案 0 :(得分:8)
暂停事务的目的是将线程的当前事务更改为新事务。这不符合嵌套事务的语义,因为新事务和挂起事务完全相互独立。没有连接级API来支持挂起事务,因此必须使用不同的连接来完成。如果您在Spring中使用JTA,则由JTA事务管理器完成。如果您正在使用DataSourceTransactionManager,您可以查看代码并查看它将作为“暂停资源”保存当前连接,并从新事务的数据源中获取新连接。