加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java – JPA OneToOneToOne映射

发布时间:2020-12-15 04:23:41 所属栏目:Java 来源:网络整理
导读:我刚刚开始使用 Java Persistence API,并且我很乐意使用它.但是,我遇到了一个小的设计决定. 假设我经营一家汽车租赁店,有几辆车,几个客户,不同的客户可以使用不同的汽车.为了存储客户最喜欢的汽车,我会使用来自客户类的@OneToMany关系,以及目前租用汽车的客
我刚刚开始使用 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不是必需的.您只需运行查询即可获得汽车或客户的租赁.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读