1

假设我在父 hbm 文件中有一组映射:

    <set cascade="all" inverse="true" lazy="false" name="children">
       <key column="parentChildId" foreign-key="fk_fk" not-null="true" on-   
         delete="cascade"/>
     <one-to-many class="Child" not-found="ignore"/>
   </set> 

是否有可能在 Parent hbm 中定​​义一个默认子节点,即当创建父节点时,会在该集合中添加一个子节点????

我知道这听起来很奇怪,但是由于一些性能问题,我必须尝试创建对服务器的最少调用(这里一个是保存父级,另一个调用是保存默认子级)。

我感谢所有的帮助。

谢谢

4

1 回答 1

2

“服务器”是什么意思?你是说数据库服务器吗?如果是这样,那么就无法在一个 SQL 语句中创建父级和子级。但是Hibernate使用的是批量更新,所以应该是非常高效的。

如果您的意思是“应用程序服务器”,那么这听起来像是一个功能问题,而不是技术问题。更改您的父级创建方法,使其同时创建一个子级。您甚至可以使用 Parent 类中的工厂方法来做到这一点:

public class Parent {
    public static Parent createParentWithDefaultChild() {
        Parent p = new Parent();
        p.addChild(new Child());
        return p;
    }
    // ...
}
于 2011-04-12T14:18:49.377 回答