首页 文章

@OneToMany Bidirectional - Join Column插入“null”值(Hibernate)

提问于
浏览
1

我有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 回答

  • 5

    在单向映射中,我遇到类似的问题,它在外键列中插入空值并得到运行时异常数据转发异常 .

    通过在 @JoinColumn 上添加nullable = false来解决问题

    @OnetoMany
    @JoinColumn(nullable=false)
    

    并删除子实体中的外键列定义 .

  • -2

    由于这是双向关系,您需要确保插入每个实体并引用关系的另一侧,因为您在产品详细信息中级联vndf,您应该执行类似这样的操作

    productDetails.setVndf(vndfList);//vndfList is having one item for example
    vndfList.get(0).setProductDetails(productDetails);
    productDetailsDao.save(productDetails);
    
  • 2
    @ManyToOne(fetch = FetchType.LAZY)
    @JoinColumn(name="PRODUCT_ID")
    private ProductDetails productDetails;
    

    PRODUCT_ID不是ProductDetails实体中的PK,这就是您的映射不起作用的原因 . 尝试将其更改为ID列,它应该可以正常工作 .

相关问题