http://hi.baidu.com/wangda_cn/item/a6f439a91eed3f3c020a4d55
在开发过程中遇到了这个问题,被折磨了几个小时,要疯掉的感觉。最终还是找到解决的办法,为了使其它程序员朋友不再像这些翻天覆地的找,特把问题的原因及解决方法记录下来。
原因:
无论是@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,而不会报错了