Hibernate - автоматически назначать внешний ключ для ребенка? - PullRequest
0 голосов
/ 11 октября 2011

Хорошо, у меня есть 2 объекта, Родитель и Ребенок. Ребенок в основном выглядит так:

public class Child implements Serializable 
{

    // primary (composite) key
    private int parentId;
    private String name;

    // random value
    private String val;

    public Child(String name, String val) {
        this.name = name;
        this.val = val;
        // note: parentId is not assigned a value
    }

    public void setParentId(int id) {

    [...]
}

Что мне нужно, так это в основном для hibernate для автоматической установки родительского идентификатора Child после создания родительского объекта. Возможно ли это или я должен добавить дочерние объекты в родительский объект после того, как родительский объект был сохранен в базе данных?

XML-отображение родителя выглядит так:

`<map name="children" inverse="true" lazy="true" cascade="all,delete-orphan">
    <cache usage="nonstrict-read-write"/>
    <key column="parent_id"/>
    <index column="child_name" type="string"/>
    <one-to-many class="myPack.Child"/>
</map>`

и xml ребенка:

<hibernate-mapping package="myPack">

    <class name="Child" table="child_tbl" lazy="true">

        <composite-id>
            <key-property name="ParentId" type="int" column="parent_id"/>
            <key-property name="Name" column="name" type="string"/>
        </composite-id>

        <property name="Val" blablabla
[...]

Ответы [ 2 ]

0 голосов
/ 29 марта 2013

Привет Дней, прежде чем я столкнулся с той же проблемой. У меня есть решение в классах аннотации. Поскольку у меня нет твоего родительского класса, позволь мне пойти с моим предположением

public class Parent implements Serializable 
{
   // Id is generated by sequence so it is not assigned when parent will be created
    @Id @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "SEQ_APP")
    @SequenceGenerator(name="SEQ_APP",sequenceName="SEQ_APP")
    private Integer id;
    private String name;

    @ManyToMany
    @JoinTable(
        name = "CHILD_TABLE",
        joinColumns = { @JoinColumn(name = "PARENT_ID")},  
        inverseJoinColumns = {@JoinColumn(name = "NAME")}
    )
    @Cascade(CascadeType.DELETE_ORPHAN)
   private Set<Child> childs= new HashSet<Child>();

   // getters and setters
}



public class Child {
       // primary (composite) key

       private int parentId;
       private String name;    }
0 голосов
/ 11 октября 2011

Если вы хотите, чтобы hibernate вставлял parent-child вместе с внешним ключом, используйте сопоставление объектов, а не идентификаторы.

Давайте возьмем пример из здесь ,

public class AMain {

 //Properties of A.
 List<ASub3> subList;
.....
}

public class ASub3 {
 .....  
 AMain parent;
 .....
}

в файле hbm.xml в AMain add,

    <list name="subList" inverse="true" cascade="all" lazy="false">
         <key column="a_id" />
         <list-index column="as3_id" />
         <one-to-many class="com.manu.hibernate.mappings.domain.ASub3" />
    </list>

в Asub3 add,

<many-to-one name="parent" class="com.manu.hibernate.mappings.domain.AMain" 
column="a_id" unique="true" cascade="save-update" />

Теперь в клиентском коде используйте бины, как показано ниже,

     AMain a = new AMain("A");
     ASub3 as3a = new ASub3("List - 1");
     ASub3 as3b = new ASub3("List - 2");
     ASub3 as3c = new ASub3("List - 3");
     as3a.setParent(a);
     as3b.setParent(a);
     as3c.setParent(a);
     List<ASub3> subList = new ArrayList<ASub3>();
     subList.add(as3a);
     subList.add(as3b);
     subList.add(as3c);

     a.setSubList(subList);

Теперь, если вы сохраните AMain, AMain и ASub3 будут обновлены (я имею в виду соответствующую таблицу) внешним ключом для AMain.

...