我有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()方法。
答案 0 :(得分:0)
虽然您的问题不明确(如何保存和删除?),我建议您设置cascade
:
<set cascade="all-delete-orphan">
作为旁注 - 避免使用您的母语。
答案 1 :(得分:0)
根据您的说明,我了解Tema
如果没有Disciplina
就不能存在:如果您从集合中删除Tema
,则希望将其删除。要告诉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>