一尘不染

多个@ManyToOne字段指向JPA / Hibernate中的同一实体

hibernate

我有一个Order具有billingAddress和的实体shippingAddress。我也有一个Address实体。我试图使单个地址表同时包含送货地址和帐单地址,因为没有什么区别它们,并且在一个或多个订单中帐单地址和送货地址可以相同。我已经在中使用@ManyToOne了地址字段Order,但是我不确定使这种双向传输正确的方法。

我有两个问题:

  1. 是否@ManyToOne适合地址字段,因为它实际上是n:2关系,我只是使用两个单独的字段来表示?如果没有,我该怎么办?
  2. 假设1.可以,那么如何使映射双向化(在Address实体中应使用哪些注释?)?可以通过在中的注释中列出多个列来完成此操作Address吗?

码:

@Entity
@Table(name = "orders")
public class Order {
  //...
    private Address shippingAddress;
    private Address billingAddress;

    @ManyToOne
    @JoinColumn(name = "shipping_address_id", referencedColumnName = "address_id", nullable = false)
    public Address getShippingAddress() {
        return shippingAddress;
    }

    @ManyToOne
    @JoinColumn(name = "billing_address_id", referencedColumnName = "address_id", nullable = false)
    public Address getBillingAddress() {
        return billingAddress;
    }
  //...
}

@Entity
@Table(name = "addresses")
public class Address {
    //address1, address2, city, state, etc.

    //how to link back to Orders?
    private Set<Order> orders;
}

阅读 732

收藏
2020-06-20

共1个答案

一尘不染

关于您的第一个问题:它是ManyToOne吗?

这取决于。如果多个订单可以具有相同的收货地址,则为ManyToOne。如果只有一个订单可以具有给定的送货地址,则为OneToOne。帐单地址也一样。

我不确定使双向关联是一个好主意。在这种情况下,我可能不会这样做。但是,如果你想让它是双向的,那么你必须让 他们
双向的。您确实在这里有两个不同的关联。因此,映射如下所示:

@OneToMany(mappedBy = "shippingAddress")
private Set<Order> shippedOrders;

@OneToMany(mappedBy = "billingAddress")
private Set<Order> billedOrders;

或者,如果该关联实际上是一个OneToOne(请参阅第一个问题的答案):

@OneToOne(mappedBy = "shippingAddress")
private Order shippedOrder;

@OneToOne(mappedBy = "billingAddress")
private Order billedOrder;
2020-06-20