zoukankan      html  css  js  c++  java
  • HQL manytoone 属性notfound, 引用外键记录不存在

    如果在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;
  • 相关阅读:
    Bzoj1072--Scoi2007排列perm
    Bzoj1041--Haoi2008圆上的整点
    Bzoj3932--Cqoi2015任务查询系统
    HDU 1024 Max Sum Plus Plus(DP)
    HDU 1029 Ignatius and the Princess IV
    【noip模拟题】数列
    Hello World
    vue-router 进阶
    vue2.0 源码解读(二)
    vue2.0 源码解读(一)
  • 原文地址:https://www.cnblogs.com/smallfa/p/15587731.html
Copyright © 2011-2022 走看看