当前位置: 首页 > 知识库问答 >
问题:

Hibernate@OneToMany更新父项时不从列表中删除子项

井旺
2023-03-14

我已经创建了纸张和Mcq问题之间的映射如下。

    public class Paper {
 @OneToMany(fetch = FetchType.EAGER, cascade =      {CascadeType.PERSIST, CascadeType.MERGE})
     @JoinTable(name = "paper_mcq",
        joinColumns = {@JoinColumn(name = "paper_id")},
        inverseJoinColumns = {@JoinColumn(name = "mcq_id")})
@JsonIgnore
private Set<Mcq> mcqs = new HashSet<>();

}

当我更新纸质实体时,它会删除所有MCQ。

SQL输出:

Hibernate: delete from paper_mcq where paper_id=?

共有1个答案

欧阳安阳
2023-03-14

我相信你的纸质物品在paperRepo。save(paper)此时没有MCQ,级联将其视为删除。我只是假设您从json接收对象,@JsonIgnore只是忽略了反序列化。

所以有多种选项可以解决这个问题:-查询MCQ并在更新之前设置它们-删除@JsonIgnore并将它们添加到json中-删除级联并手动设置

 类似资料:
  • 问题内容: 我有以下实体: 球队 } 和 USER_TEAM_ROLE 现在,当使用{UTR1,UTR3}更新包含例如Team.userTeamRoles = {UTR1,UTR2}的Team实体时,我希望删除UTR2。但是我现在的方法是,旧列表保持不变,并且只将UTR3添加到列表中。 这是我目前的做法: 我认为通过执行该列表将被重置,并且由于级联,先前的列表将被删除。 任何帮助表示赞赏。谢谢 问

  • 问题内容: 我在Hibernate中有标准协会。更新时,我正在创建新实体(使用关键字),并用必要的值(还插入ID)填充它。值来自UI。以相同的方式,我创建了子对象的新集合,用值(也插入了ID)填充每个子对象,并将集合存储在父对象中(使用setter或按方法)。 所以我的问题是:如何在更新父级时删除父级集合中的所有对象,并用新的集合替换它们。在新集合中,某些对象确实是新对象,而某些对象仅需要更新(它

  • 我试图解决这个问题已经有一段时间了,但我还没有实现100%的解决方案。首先,我必须描述我的问题。我正在开发一个餐厅应用程序,在所有实体中,我有实体成分,正如你们所知,成分可以由特定数量的其他成分组成。所以我创建了一个实体子成分,带有一个嵌入的Id。 为了保留子成分列表,我尝试了级联和去除孤儿的组合,每种组合对某些操作有效,但对其他操作无效。 我从使用CascadeType开始。所有和新的子成分成功

  • 我有两个具有一个任意关系的表 类ServiceProvider{ ... @OneTomany(Fetch=FetchType.Eager,MappedBy=“ServiceProvider”,Cascade={CascadeType.All,CascadeType.Remove},OlphanRemove=true)@OnDelete(action=OnDeleteAction.Cascade)

  • 问题内容: 从列表中删除项目时遇到麻烦。该列表是在超类中定义的,但是Hibernate批注将应用于子类中的属性访问器。超类中有两种方法可以操作列表。“添加”方法可以正常工作,但“删除”不能持久保存更改。我检查了我的Cascade设置,似乎一切正确。我在做一些不可能的事情吗?如果不是,我做错了什么吗? 这是我的课程: 我按如下方式使用TemporalAsset类的实例(请注意,我仅使用“refres

  • 我的实体更新有问题。如你所见,我有三个实体。 包含类中的列表。 包含类中的列表。 从我的SQL语句中可以看到,字段和是唯一的。我的表中只允许该组合的一行。 当我用类的新列表更新父实体()时,我希望Hibernate删除旧列表本身并创建新实体。一个一个地更新孩子是有点困难的。这就是为什么我要直接删除所有相关的孩子。 当我更新并为其提供包含具有唯一名称的和(数据库中已存在的实体)组合的列表时,我会出现