我的基本理解是,需要JTA时使用UserTransaction(例如,对多件事进行查询),而仅需要JPA时(例如,查询是原子的)使用EntityTransaction。
基本上是正确的,但是您对“多个事物”和“原子”的描述有些奇怪。JTA允许开发人员使用分布式事务以原子方式(全有或全无)对多个资源(数据库,JMS代理等)执行更改。如果仅访问一种资源(例如,一个数据库),则不需要JTA,但是事务仍然是原子的(全有或全无)。例如,当您在一个数据库上使用常规JDBC事务时就是这种情况。
考虑
UserTransaction与
EntityTransaction:
- 如果JPA是独立使用的,则使用
EntityTransaction
自己来划分事务。 - 如果JPA在与JTA集成的托管环境中使用,请使用
UserTransaction
。在EntityManager
本身挂钩到JTA的分布式事务管理器。我所知道的唯一微妙之处在于考虑了更改的效果。当EntityTransaction
使用时,JPA知道它需要刷新的变化。如果使用来控制事务UserTransaction
,则需要使用JTA注册回调registerSynchronization
,以便在事务完成之前将更改刷新到数据库。如果您将EJB与CMT(容器管理的事务)一起使用,则甚至不需要使用UserTransaction
:应用服务器会为您启动和停止事务。



