I use JDO within GAE to batch persist objects using the following method:
public void makePersistent(PersistenceManager pm,
List<Regeling> makePersistent) {
Transaction tx = pm.currentTransaction();
try {
// Start the transaction
tx.begin();
// Persist to the datastore
// pm.makePersistentAll(makePersistent);
for (int i = 0; i < makePersistent.size(); i += BATCH_SIZE) {
int last = i + BATCH_SIZE;
last = last > makePersistent.size() ? makePersistent.size()
: last;
pm.makePersistentAll(makePersistent.subList(i, last));
pm.flush();
System.out.println("Made "+last+" items persistent.");
}
// Commit the transaction, flushing the object to the datastore
tx.commit();
} catch (Exception e) {
e.printStackTrace();
} finally {
if (tx.isActive()) {
// Error occurred so rollback the transaction
System.out.println("Rolling back transaction");
tx.rollback();
}
pm.close();
}
}
This breaks:
javax.jdo.JDOUserException: One or more instances could not be made persistent
at org.datanucleus.api.jdo.JDOPersistenceManager.makePersistentAll(JDOPersistenceManager.java:791)
...
at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:582)
NestedThrowablesStackTrace:
java.lang.IllegalArgumentException: cross-group transaction need to be explicitly specified, see TransactionOptions.Builder.withXGfound both
Element {
type: "PersistentServiceResultaat$RegelingInfoLijst$Regeling"
name: "BWBR0001821"
}
and
Element {
type: "PersistentServiceResultaat$RegelingInfoLijst$Regeling"
name: "BWBR0001822"
}
So I try to set these options:
TransactionOptions ops = TransactionOptions.Builder.withXG(true);
But I can't find a method that takes a TransactionOptions
object. Where can I set these options?
Set it in jdoconfig.xml
:
<property name="datanucleus.appengine.datastoreEnableXGTransactions" value="true" />
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With