7

该主题的各种部分描述使我怀疑 BMT 与应用程序管理的 EntityManager(以及 UserTransaction 的使用)密切相关,而 CMT 与容器管理的 EntityManager 密切相关。

任何人都可以给出(或指出)BMT/CMT 与应用程序/容器管理的 EntityManager 的关系的清晰解释吗?

事务分界类型和 EntityManager 管理类型之间允许哪些组合?

  • 我可以将应用程序管理的 EntityManager 与 CMT 结合起来吗?
  • 我可以将容器管理的 EntityManager 与 BMT 结合使用吗?

另外,UserTransaction 和 BMT/CMT 与应用程序/容器管理的 EntityManager 之间有什么关系?

  • 我可以将 UserTransaction 与容器管理的 EntityManager 一起使用吗?
  • UserTransaction 是否暗示 BMT,反之亦然?

编辑:根据http://www.byteslounge.com/tutorials/container-vs-application-managed-entitymanager我可以以任何我喜欢的方式将 CMT/BMT 与 application/container-managed EntityManagers 结合起来。这仍然给我留下了关于 UserTransaction 和 BMT 之间关系的问题。一个是否暗示另一个?

编辑:与上面发布的链接相反,http ://docs.oracle.com/javaee/6/tutorial/doc/bnbqw.html#bnbra声称“应用程序管理的实体管理器不会自动传播 JTA 事务上下文。此类应用程序在执行实体操作时需要手动访问 JTA 事务管理器并添加事务分界信息。javax.transaction.UserTransaction 接口定义了开始、提交和回滚事务的方法。通过创建实例来注入 UserTransaction 的实例用@Resource 注释的变量”。对我来说,这听起来像是“应用程序管理的实体管理器需要 bean 管理的事务分界”。谁是对的?甲骨文还是 Byteslounge?

4

1 回答 1

4

我将尝试回答您的问题,但可能的场景组合比您询问的要多,我不会尝试回答它们。在容器管理的以下答案中,我的意思是 JTA(不是 RESOURCE_LOCAL)、事务范围的 EntityManager(用PersistenceContextType.TRANSACTION而不是注入PersistenceContextType.EXTENDED

我可以将应用程序管理的 EntityManager 与 CMT 结合起来吗?

是的,尽管这不是通常的用例。基本上创建的实体管理器会自动加入当前事务。您可以在 JPA 2.0 规范中找到一个示例,

7.7.1.1 Application-managed Persistence Context used in Stateless Session Bean

我可以将容器管理的 EntityManager 与 BMT 结合使用吗?

是的,我见过非官方的 例子,可以用来控制何时开始/提交/回滚事务,因为注入的 EntityManager 已自动加入事务(即您无法控制 entitymanager 何时加入当前的 JTA 事务) . 我还没有看到任何官方的例子(如果你看到了,请在评论中提供它们以确保完整性)。

我可以将 UserTransaction 与容器管理的 EntityManager 一起使用吗?

问题没有正确提出:如果UserTransaction您尝试控制事务,那么正确的问题是可能的组合:UserTransaction使用 CMT(这没有意义,因为事务由容器控制)或使用 BMT(这是典型的法律案例)。现在您通过容器管理的实体管理器(取决于 CMT 或 BMT)获得了原始问题的答案。

UserTransaction 是否暗示 BMT,反之亦然?

我会这么说,因为在 CMT 中,JTA 事务是由容器自动启动的。

对于您的最后一个问题:您在 Oracle 网页上找到的内容对我来说似乎不正确。正如我在您的第一个问题(带有官方示例)中回答的那样,您可以在 CMT 中组合应用程序管理的实体管理器(没有 UserTransaction,请查看规范中的示例)。

另外,我在不同的地方发现了一些其他的混淆,我认为官方文档实际上是 JPA 规范(以及 Java EE 规范)。如果那里写了一些东西,那不起作用,请考虑(并请报告!)这是一个错误。

于 2015-02-04T15:49:01.523 回答