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

之前使用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 的对象时,其中属性a 的数据可能不存在,但通过代码判断却不为空,即会出现所述错误。

解决方法:

在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;
}

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


 


 

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值