hibernate-取消关联外键引用数据丢失抛异常的设置@NotFound
hibernate项目里面配了很多many-to-one的关联,后台在查询数据时已经作了健全性判断,但还是经常抛出对象找不到异常:
org.hibernate.ObjectNotFoundException: No row with the given identifier exists
因为系统给用户使用过程中库表的数据会常发生变化,最常见的是人员变化,原先引用的User 在库表没了,hibernate 多对一关联,多的这端引用的一的那端,如此引用值在一的那端找不到数据,默认就会抛出异常;而后台判断控制不了此问题。解决办法:
在many-to-one的这端加上属性:not-found=ignore
hibernate many-to-one的属性not-found,用来指定引用的外键不存在时如何处理:
exception(默认)抛出异常
ignore 忽略
如果使用注解, 可以用如下的注解
@NotFound(action=NotFoundAction.IGNORE)
举个例子:
@ManyToOne(cascade={CascadeType.PERSIST},targetEntity=BeanInfo.class)
@JoinColumn(name="bean_id",updatable=false)
@NotFound(action=NotFoundAction.IGNORE)
private BeanInfo beanInfo;
如果不是使用的注解, 而是使用的配置文件
在中设置not-found="ignore"