Google App Engine - 无法在单个交易中对多个实体组进行操作

Tay*_*ese 1 java google-app-engine spring jpa datanucleus

如果两个实体的类型都是PersistentLogin,为什么我会收到以下例外?我认为这意味着他们属于同一个实体组,但我猜这是一个不正确的假设.任何想法如何解决这一问题?

这是代码:

// the class is marked with @Transactional
@Override
public final void removeUserTokens(final String username) {
    final Query query = entityManager.createQuery(
        "SELECT p FROM PersistentLogin p WHERE username = :username");
    query.setParameter("username", username);

    for (Object token : query.getResultList()) {
        entityManager.remove(token);
    }
}
Run Code Online (Sandbox Code Playgroud)

这是例外:

Caused by: javax.persistence.PersistenceException: Illegal argument
    at org.datanucleus.jpa.NucleusJPAHelper.getJPAExceptionForNucleusException(NucleusJPAHelper.java:260)
    at org.datanucleus.jpa.EntityTransactionImpl.commit(EntityTransactionImpl.java:122)
    at org.datanucleus.store.appengine.jpa.DatastoreEntityTransactionImpl.commit(DatastoreEntityTransactionImpl.java:50)
    at org.springframework.orm.jpa.JpaTransactionManager.doCommit(JpaTransactionManager.java:467)
    ... 42 more
Caused by: java.lang.IllegalArgumentException: can't operate on multiple entity groups in a single transaction. found both Element {
  type: "PersistentLogin"
  name: "1WfCYx8bmwUGkjzP2PpmFA=="
}
 and Element {
  type: "PersistentLogin"
  name: "SfI0P8RVBjTvu0WHMSuaVA=="
}
Run Code Online (Sandbox Code Playgroud)

Thi*_*ilo 5

相同的实体组意味着实体具有共同的父实体.

两个顶级实体永远不会在同一个实体组中.

任何想法如何解决这一问题?

最简单的方法是放宽交易要求.在您的情况下,这将意味着逐个删除PersistentLogin实体(尽力而为循环,尽可能删除,重试错误,不保证原子性).

如果您想将同一用户的PersistentLogin放在同一个实体组中,则需要对数据模型进行相当大的更改,同时对整体性能产生不确定的影响.

对于非关系数据库,您必须编写应用程序代码而不依赖于数据存储上的事务.他们只是在我们已经习惯的程度上不支持他们.