HQL many-to-one 属性not-found, 引用外键记录不存在

如果在Hibernate项目里面配了很多many-to-one的关联,即使后台在查询数据时已经作了健全性判断,但还是会经常抛出对象找不到异常:org.hibernate.ObjectNotFoundException: No row with the given identifier exists。

比如系统在用户的使用过程中,数据库表的数据会常发生变化,最常见的是人员变化,原先引用的User在数据库表没了,而Hibernate做了多对一关联,多的这端引用的一的那端,一旦引用值在一的那端找不到数据,默认就会抛出异常,而后台判断却控制不了此问题。

Hibernate Reference有介绍到,在多对一关系中,即many-to-one标签元素中有一个属性not-found,用来指定引用的外键不存在时将如何处理。

not-found属性有两个候选值:

1.exception(默认)抛出异常。

2.ignore,忽略异常,不抛出异常。

<many-to-one name="project" column="projId" 
        class="com.toone.yanggb.model.Project" not-found="ignore"/>

在不配置这个属性的情况下,Hibernate会采用默认的抛出异常来处理;当配置了not-found属性并将值设置为ignore之后,就可以取消关联外键引用数据丢失抛异常的设置。

另外的,Spring/Hibernate还提供有@NotFound注解,效果和not-found属性相当。

@NotFound(action = NotFoundAction.IGNORE)
@ManyToOne(cascade = {CascadeType.PERSIST}, targetEntity = Topic.class)
@JoinColumn(name = "topic_id", updatable = false)
@NotFound(action = NotFoundAction.IGNORE)
private Topic topic;
上一篇:TZOJ3465: How many seats(数位DP)


下一篇:go 编译时报pipe: too many open files 解决方案