gpt4 book ai didi

java - 使用多对多关系使用 hibernate 进行低效保存

转载 作者:行者123 更新时间:2023-12-02 03:32:34 25 4
gpt4 key购买 nike

我有一个包含 25 个 MyApplication 对象的列表,我想使用 hibernate/JPA 保存它们。这是通过以下方法完成的:

MyApplicationRepository.saveAll(myAppList);

但是我注意到,当在数据库中插入/更新这 25 个列表时,hibernate 创建了超过 60.000 个 MyApplication 对象(接近该实体数据库中已有的记录总数)。我没有太多的 hibernate 经验,这让我相信我创建了一个低效的实体关系。 MyApplication 类的一部分:

public class MyApplication {
@ManyToMany(fetch = FetchType.LAZY, cascade = CascadeType.ALL)
@JoinTable(name = "APPLICATION_CATEGORY", joinColumns = {
@JoinColumn(name = "applicationid", nullable = false, updatable = false) },
inverseJoinColumns = { @JoinColumn(name = "categoryid",
nullable = false, updatable = false) })
private Set<Category> categorySet;


@OneToMany(mappedBy = "myApplication",
cascade = CascadeType.ALL, fetch = FetchType.LAZY)
private Set<Screenshot> screenshotSet;
}

类别(MyApplication 的多对多关系的一个示例):

public class Category {
@ManyToMany(fetch = FetchType.LAZY, mappedBy = "categorySet")
private Set<MyApplication> myApplicationSet;
}

截图类:

public class Screenshot {
@ManyToOne
@JoinColumn(name = "applicationid")
private MyApplication myApplication;
}

我做错了什么导致 Hibernate 在保存时创建如此多的 MyApplication 实例?

注1:最终MyApplication的所有信息及其类别和屏幕截图信息都正确保存在数据库中。

注 2:重要的是,不仅要保存 MyApplication,还要保存其所有类别和屏幕截图中的所有内容。

最佳答案

我能够解决这个问题。该问题是由多对多关系的双向性质引起的。这导致该类别在保存之前还会从数据库中查询所有应用程序。由于这不是我想要的,因此我通过从 Category 类中删除 myApplicationSet 将其转换为单向关系来解决该问题。现在只构建了 25 个 MyApplication 实例来保存 25 个应用程序,并且我的内存使用量保持稳定。

关于java - 使用多对多关系使用 hibernate 进行低效保存,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56876626/

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