[JPA] javax.persistence.EntityNotFoundException: Unable to find XXXX with id 0 问题原因

在开发过程中遇到了这个问题,被折磨了几个小时,要疯掉的感觉。最终还是找到解决的办法,为了使其它程序员朋友

不再像这些翻天覆地的找,特把问题的原因及解决方法记录下来。

原因:

    无论是@OneToOne 还是@ManyToOne,出现这个原因都是因为子表(被关联表)中没有主表(关联表)中ID所对

应的记录。

解决办法:

    1. 检查为什么子表中没有主表中ID对应的记录

    2. 如果子表中没有主表ID对应的记录也可以正常加载数据,那么需要在主表字段上加一个@NotFound Annotation。示例如下:

    @OneToOne(optional=true )
    @JoinColumn(name="companyId",insertable=false, updatable=false)
    @NotFound(action=NotFoundAction.IGNORE)
    private Company company;

    这样,当子表中没找到数据时,主表中对应的field就是null,而不会报错了。

你可能感兴趣的:([JPA] javax.persistence.EntityNotFoundException: Unable to find XXXX with id 0 问题原因)