gpt4 book ai didi

java - Hibernate:映射@OneToMany/@ManyToOne问题(不使用实体主键)

转载 作者:行者123 更新时间:2023-12-02 08:11:13 33 4
gpt4 key购买 nike

我是 Hibernate/Spring 的新手,尝试在创建一个小型 Web 实用程序的同时映射遗留数据库,这应该可以减轻同事的一些工作。由于我已经映射了实体并可以访问底层数据,因此我在以后的道路上遇到了一些问题。长话短说,我有两个实体,客户

@Entity
public class Customer implements Serializable{

@Id
@Column(name = "RecordID")
private Integer id;

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

@OneToMany
@JoinColumn(name="CUSTOMER1", referencedColumnName="CUSTOMERNAME1")
private List<Contract> contracts;
}

和契约(Contract):

@Entity
public class Contract implements Serializable {

@Id
@Column(name = "RECORDID") //RecordID
private Integer id;

@Column(name = "CONTRACTID1") //ContractID1
private String contractId;

@Column(name = "CUSTOMER1") //Customer1
private String customerName;

//@ManyToOne
//private Customer customer; // how can I write the reverse mapping?
}

从客户到契约(Contract)的映射有效(一个客户可以拥有许多契约(Contract),我可以使用客户中的“列表契约(Contract)”字段获取所有契约(Contract),但我的问题是,我怎样才能实现相反的目标 - 也就是说,让客户,映射到哪个合约?

最佳答案

Java API 有一些如何使用 ManyToOne 注释的示例: http://java.sun.com/javaee/6/docs/api/javax/persistence/ManyToOne.html

类似下面的内容:

客户类别:

@OneToMany(mappedBy="customer", cascade=CascadeType.ALL)
private List<Contract> contracts;

契约(Contract)类别:

@ManyToOne
@JoinColumn(name="customer_id", nullable=false)
private Customer customer;

关于java - Hibernate:映射@OneToMany/@ManyToOne问题(不使用实体主键),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7387870/

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