gpt4 book ai didi

java - 当实体中存在关系时,我可以仅使用实体的 id 而不是从数据库中获取实体吗?

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

我将 Spring Data JPA 与 Hibernate 结合使用。

假设我定义了以下实体:

@Entity
@Table(name = "foods")
public class Food {

@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "food_id")
private Long foodId;


@ManyToOne(fetch = FetchType.EAGER)
@JoinColumn(name = "food_type_id")
@NotNull
private FoodType foodType;

...
}


@Entity
@Table(name = "food_types")
public class FoodType {

public static final Integer PERISHABLE;
public static final Integer NON_PERISHABLE;

@Id
@Column(name = "food_type")
private Integer foodTypeId;

private String name;

...
}

每次我想创建一个 Food 实体并将其保存到数据库时,当前代码如下所示:

Food food = new Food();
FoodType foodType = foodTypeRepository.findById(FoodType.PERISHABLE); // Call to DB to get Entity
food.setFoodType(foodType);
....

foodRepository.save(food);

如果我们认为 FoodType 在数据库中是恒定的。我可以这样使用它吗:

Food food = new Food();
FoodType foodType = new FoodType();
foodType.setFoodTypeId(FoodType.PERISHABLE); // No Call to DB
food.setFoodType(foodType);
....

foodRepository.save(food);

我已经测试过它,是的,我可以这样使用它,hibernate 将保存 Food 实体,但是是否有任何缺点、陷阱等......我没有看到。

PS。这只是一个简单的例子来说明这个想法,它是旧遗留项目的一部分,我无法修改它以从数据库中删除常量,而是使用枚举。

最佳答案

为了避免额外调用数据库,您应该使用:

FoodType foodType = foodTypeRepository.getOne(FoodType.PERISHABLE); 

在幕后它调用 EntityManager.getReference 无需加载实体数据即可获取对实体的引用,这与 foodTypeRepository.findById 相反导致调用 EntityManager.find 获取实体及其数据

另请参阅this section hibernate 文档。

附注您不能使用:

Food food = new Food();
FoodType foodType = new FoodType();
foodType.setFoodTypeId(FoodType.PERISHABLE);

在这种情况下, hibernate 考虑 foodType作为一个 transient 实体(不与 persistence context 关联),并且如果您有正确的 cascading ,将尝试将其保存为新记录。在您的@ManyToOne上协会。

附注正如 documentation 中提到的方法JpaRepository#getOne(ID)已弃用,您应该使用 JpaRepository#getById(ID)相反。

关于java - 当实体中存在关系时,我可以仅使用实体的 id 而不是从数据库中获取实体吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67173987/

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