1

我在 GoogleApp 引擎中有一个 Spring 应用程序,它使用 JDO 来持久化对象。所以我在我的服务层中以这种方式使用它来保存事务(使用@Transactional 注释)。

@Transactional
public void save(Object object) {
    dao1.save(object); // dao1 saves using JDO
    Object object2 = generate1Object(object)
    dao2.save(object2); // dao2 saves using low level API
    Object object3 = generate2Object(object)
    dao3.save(object3); // dao3 saves using JDO
}

我遇到的问题是我需要使用低级 API 来持久化 object2(因为它是高级保存,无法使用 JDO 完成)。我遇到的问题是我不知道如何将它们全部保存在同一个事务中。如果 dao3 在保存 sving 时失败,love 关卡不会回滚。

所以在 dao2 我坚持这样:

//save using low-level API
public void save(Object object){
    DatastoreService datastore = DatastoreServiceFactory.getDatastoreService();
    Entity entity = generateEntity(object);
    datastore.put(entity);
}

在 dao1 和 dao3(使用 JDO 的)中,我有这样的东西:

//save using JDO
public void save(Object object) {
    PersistenceManager pm = PMF.get().getPersistenceManager();
    pm.makePersistent(object);
}

我已经看到数据存储对象有一个名为:

datastore.getCurrentTransaction()

但对我来说是空的。我怎样才能让低级别知道JDO的事务并将三个daos保持在同一个事务中。

谢谢。

4

1 回答 1

1

只需正常使用 jdo 并获取 bigtable 连接

tx.begin();
...

// Get hold of native connection
JDOConnection jdoConn = pm.getDataStoreConnection();
... cast "jdoConn.getNativeConnection()" to the right type
... (do something with the connection)
jdoConn.close(); // Hands it back to JDO

tx.commit();

至少这是理论,假设 GAE/J 实现它

于 2011-03-24T10:00:11.903 回答