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