有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

java是否使JDO PersistentManager的持久性不足以创建子元素?

我有一些这样的代码

class root extends DomainObject{
Collection childElements;
Collection childElements2;
.....
//define other child element collections


Collection getChildElements(){
 return childElements;
}
// define other childElements getter/setter

还有我的包裹。jdo定义了如下所示的映射

      <class name="root" identity-type="datastore" detachable="true" persistence-capable-superclass="com.xxx.DomainObject">
        <inheritance strategy="new-table"/>
        <field name="childElements" persistence-modifier="persistent" default-fetch-group="true">
            <collection element-type="com.my.CustomClass" />
            <join/>
            <order column="idx"/>
            <extension vendor-name="jpox" key="cache-lazy-loading" value="false"/>
        </field>    

自定义类结构可能如下所示

class CustomClass extends DomainObject{
String name;
Collection otherElements;
.....


String getName(){
return name;
}    
Collection getOtherElements(){
 return otherElements;
}

现在来创建com对象。我的CustomClass代码如下所示

persistenceManager().currentTransaction().begin();
CustomClass customObj = new CustomClass();
customobj.setName("someName");
//set other values    
persistenceManager.makePeristent(customObj);//persist
SomeUtil.getRoot().getChildElements().add(customObj);//add to its owner
persistenceManager.currentTransaction().commit();

SomeUtil中getRoot()的代码如下所示

 Query q = persistenceManager.newQuery( root.class );
 Collection c = (Collection)q.execute();
  persistenceManager.retrieveAll( c );
   return (root)c.iterator().next();

我不明白的是,为什么我们需要向所有者添加这个新的自定义对象SomeUtil.getRoot().getChildElements().add(customObj); 删除代码看起来也很相似,即首先从其所有者的集合中删除对象,然后调用persistenceManger的deletePersistent

我的问题是 我们真的需要显式地将这个对象添加到父对象吗?光是makePeristent()还不够吗?我之所以这么问,是因为我看到这个“getRoot()”会对性能造成一些影响(即使底层对象是延迟加载的,但当这些集合的数量很大时,也会对性能造成一些影响)

在运行时,我们使用这个“根”对象的缓存/可分离副本(比如深度克隆),并且只从这个“根”对象检索任何必需的元素。如果对数据库做了任何修改,那么我们将使这个缓存无效,重新加载这个根目录并再次缓存它

删除在父元素中显式添加或删除子元素的代码是否安全?或者,根据我们定义的映射(并且考虑到我们在运行时依赖缓存(克隆)根来检索所有子元素的事实),它真的是必需的吗? 请注意,在运行时(深度用户克隆)和对象创建期间,我们没有使用相同的“根”。只是我们在运行时依靠“root”获取其他元素。 请告诉我是否有任何机构处理过这种情况


共 (2) 个答案

  1. # 1 楼答案

    我已经对此进行了测试,并观察到,如果您在不了解父元素的情况下添加子元素,则无法使用父元素检索该子元素

    persistenceManager().currentTransaction().begin();
    CustomClass customObj = new CustomClass();
    customobj.setName("someName");
    //set other values    
    persistenceManager.makePeristent(customObj);//persist
    //comment this
    //SomeUtil.getRoot().getChildElements().add(customObj);//add to its owner
    persistenceManager.currentTransaction().commit();
    

    后来,当我加载父元素时,我发现没有检索到子元素

     Collection c = SomeUtil.getRoot().getChildElements()
     // Iterate over this collection and found that element is not present
    

    正如我前面所说,我们在运行时依赖这个根对象来检索任何子元素。 尽管直接查询孩子们是可行的,但这不是我们的选择

    看来我们只能通过将该子级添加到父级来实现这一点。 但我们希望避免这种情况,因为检索父(根)会影响性能(即使是在延迟加载时),因为此根有许多其他子集合元素。在运行时,我们通常加载此根目录一次并缓存干净的副本

  2. # 2 楼答案

    JDO规范中很好地定义了可访问性的JDO持久化。DataNucleus日志告诉您什么是持久化的以及何时持久化的。我强烈建议阅读这两个参考资料