Java 从集合中删除元素
我有两门课,一门是专业课,一门是家庭作业。 在Hibernate中,我将其映射为一对多关联,如下所示:Java 从集合中删除元素,java,hibernate,orm,one-to-many,hbm,Java,Hibernate,Orm,One To Many,Hbm,我有两门课,一门是专业课,一门是家庭作业。 在Hibernate中,我将其映射为一对多关联,如下所示: <class name="model.Disciplina" table="devgar_scoala.discipline" > <id name="id" > <generator class="increment"/> </id> <set name="listaTeme" table="devgar_scoala.tem
<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”中添加insert行,但不会删除任何行,并且不会引发异常
我正在使用合并方法。虽然您的问题不清楚如何保存和删除?,但我建议您需要设置级联:
作为旁注-避免使用母语的名称。根据您的描述,我理解没有规则的Tema是不可能存在的:如果您从集合中删除Tema,您希望将其删除。要让Hibernate执行此操作,必须使用cascade=all delete orphan 请参阅
<set 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>