gpt4 book ai didi

java - Hibernate 多对多映射和 cascade=delete

转载 作者:塔克拉玛干 更新时间:2023-11-01 21:43:41 24 4
gpt4 key购买 nike

我有一个映射(只有重要的部分):

<class name="xyz.Role" table="ROLE" lazy="true">  <id name="id" type="java.lang.Integer">    <column name="ROLE_ID"/>    <generator class="increment"/>  </id>  <set name="assignments" lazy="true" table="PERSON_ROLE" cascade="delete" inverse="true">    <key column="ROLE_ID" />    <many-to-many class="xyz.Person" column="PERSON_ID" />  </set> </class>

<class name="xyz.Person" table="PERSON" lazy="true">  <id name="Id" type="java.lang.Integer">    <column name="TPP_ID"/>    <generator class="increment"/>  </id>  <set name="roles" lazy="true" table="PERSON_ROLE" cascade="save-update">    <key column="PERSON_ID" />    <many-to-many class="xyz.Role" column="ROLE_ID" />  </set> </class>

有了这个映射,当我删除一个角色时,拥有这个角色的人也被删除了。我想要实现的是在删除角色时删除关联(PERSON_ROLE 表中的行)。有什么办法可以实现吗?

最佳答案

Cascade 在实体级别上工作。由于 Person_Role 未映射为实体,因此级联无法帮助您 AFAIK。

您可以在从 Person_RoleRole 的外键上使用数据库级别的“级联删除”。

或者您可以 - 正如 sfussenegger 指出的那样 - 以编程方式删除关联。请注意,由于您将关联映射到两个实体,Person_Role 中的每一行都将在您的对象模型中出现两次。在这种情况下,建议从两个集合中删除相关条目,以免破坏您的对象模型。然而,Hibernate 在持久化更改时只会查看未使用 inverse="true" 映射的关联的末尾。也就是说,要从与您当前映射的关联中删除,您必须从 Person.roles 中删除,而不是从 Role.assignments 中删除:

for (Person p : role.assignments) {
person.roles.remove(role)
}

或者您可能希望用关联实体替换多对多映射,在这种情况下您可以简单地使用级联。这将使您可以更轻松地向作业添加更多信息。例如,如果您必须表达“Joe 30% 的工作在 QA 上,70% 的工作是需求工程师”,您可以简单地将该字段添加到关联中。

关于java - Hibernate 多对多映射和 cascade=delete,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2266124/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com