Hibernate JPA —— Unable to find ... with id 0 错误

来源:互联网 发布:手机粉碎软件 编辑:程序博客网 时间:2024/04/28 04:26

之前使用Hibernate JPA 的实体映射时并没有出现此错误,今天再次启动之前的项目时,报此错。此错误特殊之处在于,当使用JPA 获取实体时,其参考的实体若不存在,则判断null 为false ,查看里面属性可见全部为null,但调用该参考实体的任何方法都会导致异常。


错误重现:

假设实体A 中多对一实体B:

@Entity("TABLE_A")class A{@Id@Column("TABLE_A_ID")private int aId;}


实体B 对实体A 则是一对多关系:

@Entity("TABLE_B")class B{@Id@Column("TABLE_B_ID")private int bId;@ManyToOne( fetch = FetchType.LAZY,optional=true)@JoinColumn("A_ID")private A a;}

说明:

optional 为true,则参考表数据必须存在时插入或取数据才会成功。

当用JPA 取出某个B 的对象时,其中aSet 的数据可能不存在,但却有不为空,即会出现所述错误。


解决方法:

在optional 为true 的参考属性上,加 @NotFound(action=NotFoundAction.IGNORE) 注解,当参考数据不存在时,则参考数据为null。所以,最好为:

@Entity("TABLE_B")class B{@Id@Column("TABLE_B_ID")private int bId;@ManyToOne( fetch = FetchType.LAZY,optional=true)@NotFound(action=NotFoundAction.IGNORE)@JoinColumn("A_ID")private A a;}


关于为何出现此错误的原因,不太了解,因为之前不加这个注解,是没有出现此错误的。







阅读全文
0 0
原创粉丝点击