org.hibernate.ObjectNotFoundException: No row with the given identifier exists

问题产生原因: 有一个对象A,关联了对象B ,关联关系可以使 ManyToOne,On

eToOne 等,如果我们在数据库中清除了B对象,但是B对象还在A表中存在外键,这时候Hibernate检查这个关系的时候,会报出这个异常。但是A与B在数据库 为范围内不能耦合过紧,只能pojo中建立关联关系,此时要注意,清除A表中的外键,可以解决此问题,一般的垃圾数据会造成业务系统不能正常运转。
第二个原因: 查询的时候,假设对象A与B有着一对一的关系,一般我们配置 @On
eToOne @JoinColumn(name = "xxx"),如果B被删除了,但是A中还维护这个外键关系 要配置 @OneToOne(fetch = FetchType.LAZY) @JoinColumn(name = "xxx") 的模式,不知道为什么默认不是lazy的,还要配置一下fetch = FetchType.LAZY
本要急于测试所以直接设置为不关联not-found="ignore" Hibernate的many-to-one的元素的一个属性:not-found今天看Hibernate Reference,看到多对一关系时,看到mant-to-one元素有一个属性:not-found。用来指定引用的外键不存在时将如何处理:
  • exception(默认)抛出异常
  • ignore 忽略

以前不知道有这个属性,Hibernate就采用默认的抛出异常来处理了。经常出现显示一个项目的列表时没有数据。

posted @ 2015-02-06 15:14  siashan  阅读(617)  评论(0编辑  收藏  举报