我有2个模型/注释类,ProductDetails和VnfDetails . 我想使用JPA HIbernate加入带有@OnetoMany关系的2个表
ProductDetails 模型类在下面与@OnetoMany Mapping:
@Entity
@Table(name="product_details")
public class ProductDetails {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name="ID")
private int id;
@Column(name="PRODUCT_ID")
private String productId;
@Column(name="PRODUCT_NAME")
private String productName;
@OneToMany(mappedBy="productDetails", cascade=CascadeType.ALL)
private Set<VnfDetails> vnfd;
public Set<VnfDetails> getVnfd() {
return vnfd;
}
public void setVnfd(Set<VnfDetails> vnfd) {
this.vnfd = vnfd;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getProductId() {
return productId;
}
public void setProductId(String productId) {
this.productId = productId;
}
public String getProductName() {
return productName;
}
public void setProductName(String productName) {
this.productName = productName;
}
VnfDetails 低于@CanytoOne和JoinColumn:
@Entity
@Table(name="vnf_details")
public class VnfDetails {
@Id
@Column(name="VNF_ID")
private String vnfId;
@Column(name="VNF_NAME")
private String vnfName;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name="PRODUCT_ID")
private ProductDetails productDetails;
public ProductDetails getProductDetails() {
return productDetails;
}
public void setProductDetails(ProductDetails productDetails) {
this.productDetails = productDetails;
}
public String getVnfId() {
return vnfId;
}
public void setVnfId(String vnfId) {
this.vnfId = vnfId;
}
public String getVnfName() {
return vnfName;
}
public void setVnfName(String vnfName) {
this.vnfName = vnfName;
}
当我插入数据时,数据将被插入,但 VnfDetails 表中的 PRODUCT_ID 为空 .
它应该是具有PRODUCT_DETAILS表的“ ID ”的外键 .
无法解决问题 .
3 回答
在单向映射中,我遇到类似的问题,它在外键列中插入空值并得到运行时异常数据转发异常 .
通过在
@JoinColumn
上添加nullable = false来解决问题并删除子实体中的外键列定义 .
由于这是双向关系,您需要确保插入每个实体并引用关系的另一侧,因为您在产品详细信息中级联vndf,您应该执行类似这样的操作
PRODUCT_ID不是ProductDetails实体中的PK,这就是您的映射不起作用的原因 . 尝试将其更改为ID列,它应该可以正常工作 .