gpt4 book ai didi

java - 如何决定在 JPA 中应使用哪种实体关系

转载 作者:行者123 更新时间:2023-12-02 11:05:34 26 4
gpt4 key购买 nike

我有两个实体类:Order 和 Shop。一个订单应该属于一个店铺。多个订单也可以属于一个店铺。我现有的映射是从订单到商店类的一对一单向映射。并且它正在工作。

@Entity
@Table(name = "order")
public class Order implements Serializable {

@Id
@Column(name = "id")
private Long id;

@Column(name = "orderno")
private Long orderNumber;

@OneToOne
@JoinColumn(name = "shopid")
private Shop shop;

..
}
@Entity
@Table(name = "shop")
public class Shop implements Serializable {

@Id
@Column(name = "id")
private Long id;

@Column(name = "key")
private String key;

@Column(name = "name")
private String name;

..
}

现在我发现 Order 到 Shop 可能是 ManyToOne 关系并且应该可以工作。现在我想知道这两个选项之间有什么区别以及应该使用哪一个。

此外,我也不是 100% 确定如何决定应该使用哪一种实体关系,例如一对一、一对多、多对一、多对多,以及关系应该是单向的还是双向的。任何解释或建议的阅读都会有帮助。

最佳答案

当商店只能有一个订单时,您应该选择一对一关系。

一对多,即一个商店可以有多个订单。多对一与前一个正好相反,多个订单可以属于同一家商店。

多对多是指一个商店可以有多个订单,并且这些订单同时可以属于不同的商店。

关于java - 如何决定在 JPA 中应使用哪种实体关系,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50999642/

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