【发布时间】:2012-08-29 08:01:26
【问题描述】:
PersistenceManager 的 makePersistent 方法工作不可靠。一个相同的junit-test正在工作,过了一会儿又失败了?! 我有一个包含其他对象集合的对象。这意味着 1-n 关系。 我的问题是我的类的 junit-test 有时会失败,因为集合中的对象没有正确保存。 我通常使用事务,但persistanceManager 是事务可选的
我尝试在每次 createObject 并提交后检查 objectState... 我发现成功提交后集合中的对象没有 systemId(应该是自动生成的)但处于空心/持久非事务状态。
这意味着有时它们是(如果它们被持久化的话):
评论 [systemId=Project(1)/Comment(6), JDO-ObjectState=hollow/persistent-nontransactional]
有时它们是(如果它们没有被持久化并且父对象的 refach 包含一个空集合) 评论 [systemId=null, JDO-ObjectState=hollow/persistent-nontransactional]
当然,如果所有存储的对象都有一个 systemId,我可以手动检查,但这种方法一点也不好。提交应该失败!
我不明白它有时有效,有时无效!这意味着我的代码不应该是错误的,这是一个错误...... 请帮帮我
PS:如有需要,我可以发布一些代码!
@PersistenceCapable
public class Ble implements Serializable, JDOObject<Ble> {
/**
*
*/
private static final long serialVersionUID = 1L;
// NotNull
@PrimaryKey
@Persistent(valueStrategy = IdGeneratorStrategy.IDENTITY)
private Key systemId;
// NotNull
@Persistent
private Key parentId;
// NotNull
@Persistent
@Extension(vendorName = "datanucleus", key = "gae.parent-pk", value = "true")
private Key projectId;
// NotNull
@Persistent
private String title;
@Persistent
private int position;
@Persistent
private boolean hasChildren;
@Persistent
private BleData requirementData;
@Persistent
private List<Comment> comments;
//getter/setter
}
子对象
@PersistenceCapable
public class Comment implements Serializable, JDOObject<Comment> {
/**
*
*/
private static final long serialVersionUID = 1L;
@PrimaryKey
@Persistent(valueStrategy = IdGeneratorStrategy.IDENTITY)
private Key systemId;
@Persistent
private String text;
@Persistent
private long createdTimestamp;
//getter//Setter
}
【问题讨论】:
-
看日志会告诉你很多。
-
好的,我在哪里可以找到“日志”?
-
你定义它去哪里? “log4j.properties”会定义它。
-
您发布的日志处于 INFO 级别(因此省略了 DEBUG 级别的所有有用内容)。使用 GAE JDO 插件 v2.x
-
v2.x 是 Google 的默认安装(使用 SDK 1.7.1)code.google.com/p/datanucleus-appengine/wiki/…
标签: java google-app-engine persistence jdo datanucleus