编程语言
首页 > 编程语言> > java – JPA OneToOneToOne映射

java – JPA OneToOneToOne映射

作者:互联网

我刚刚开始使用Java Persistence API,并且我很乐意使用它.但是,我遇到了一个小的设计决定.

假设我经营一家汽车租赁店,有几辆车,几个客户,不同的客户可以使用不同的汽车.为了存储客户最喜欢的汽车,我会使用来自客户类的@OneToMany关系,以及目前租用汽车的客户,来自汽车类的@OneToOne.

现在,我应该如何存储客户驾驶的特定车辆的公里数?例如,使用MySQL数据库,我将创建一个包含三个(具有id的四个)列的表:customer_id,car_id和km. customer_id和car_id将是FK,公里……是不言自明的.

JPA的最佳方法是什么?我可以存储一个@OneToMany对象,例如来自客户的类,就像一对对象列表.第一个是汽车,第二个是客户驾驶汽车的公里数.但这感觉不对.有什么建议吗?

解决方法:

你可以拥有一个名为RentalCarMileage的实体,如下所示:

@Entity
public class RentalCarMileage implements Serializable {

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Long id;

    @ManyToOne
    private Car car;

    @ManyToOne
    private Customer customer;

    @Column
    private BigDecimal mileage;
}

@Entity
public class Customer implements Serializable {

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Long id;

    @OneToMany(mappedBy = "customer")
    private List<RentalCarMileage> rentals;

}

@Entity
public class Car implements Serializable {

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Long id;

    @OneToMany(mappedBy = "car")
    private List<RentalCarMileage> rentals;

}

此映射假定您希望具有双向关联,但@OneToMany不是必需的.您只需运行查询即可获得汽车或客户的租赁.

标签:java,mysql,jpa,hibernate,hibernate-mapping
来源: https://codeday.me/bug/20190728/1560629.html