0

我有 2 个课程 Tema(家庭作业)和 Disciplina(课程),其中一个课程有一组家庭作业。在 Hibernate 中,我已将其映射到一对多关联,如下所示:

<class name="model.Disciplina" table="devgar_scoala.discipline" >
<id name="id"  >
    <generator class="increment"/>
</id> 
<set name="listaTeme" table="devgar_scoala.teme">
    <key column="Discipline_id" not-null="true" ></key>
    <one-to-many class="model.Tema" ></one-to-many>
</set>
</class>

<class name="model.Tema" table="devgar_scoala.teme" >
<id name="id">
    <generator class="increment" />
</id>
<property name="titlu" type="string" />
<property name="cerinta" type="binary">
    <column name="cerinta" sql-type="blob" />
</property>
</class>

问题是它会添加(在表'Teme'中插入行)但它不会删除任何行并且我没有抛出异常。

我正在使用 merge() 方法。

4

2 回答 2

0

尽管您的问题尚不清楚(如何保存和删除?),但我建议您需要设置cascade

<set cascade="all-delete-orphan">

作为旁注 - 避免使用您的母语命名。

于 2010-04-11T13:38:48.763 回答
0

根据您的描述,我知道 a没有它就Tema不能存在Disciplina:如果您Tema从集合中删除 a ,您希望它被删除。要告诉 Hibernate 这样做,您必须使用cascade="all-delete-orphan".

<set name="listaTeme" table="devgar_scoala.teme" cascade="all-delete-orphan">
    <key column="Discipline_id" not-null="true" ></key>
    <one-to-many class="model.Tema" ></one-to-many>
</set>

请参阅在线文档

于 2010-04-11T14:02:16.513 回答