关于hibernate的 No row with the given identifier exists

栏目: Hibernate · 发布时间: 7年前

内容简介:网上出现此问题大概原因有以下几种:但是我本地不是,我是多的一方数据不存在,废话不多先上代码:以上是实体类对应的为伪代码,接下来是业务操作:

网上出现此问题大概原因有以下几种:

  • 多对一配置中,一的一方数据不存在时报此异常
  • 双向关联的一方数据不存在时报此异常

但是我本地不是,我是多的一方数据不存在,废话不多先上代码:

// 伪代码
class Class{
    @Id
    Long id;
    @OneToMany(cascade = CascadeType.DETACH,mappedBy = "clazz")
    List<Student> students;
    
    public Class(Map<String,Object> param){
        // 构建新的对象
        Class newClazz = new Class();
        newClazz.setId((Long)param.get("id"));
        
        // 构建新的学生对象
        List<Map<String,Object>> studentMaps = param.get("students");
        students = new ArraryList();
        studentMaps.forEach(map -> {
            Student st = new Student();
            st.setId((Long)map.get("id"));
            students.add(st);
        })
    }
}

class Student{
    @Id
    Long id;
    @ManyToOne(cascade = CascadeType.DETACH)
    @JoinColumn(name="class_id")
    Class clazz;
}

复制代码

以上是实体类对应的为伪代码,接下来是业务操作:

class ClassManagerImpl implements IClassManager{
    
    void saveOrUpdate(Map<String,Object> params){
        Class newClass = new Class(params);
        Class oldClass = classDao.get(newClass.getId());
        if(oldClass!=null){
            newClass.setCreateDate(oldClass.getCreateDate());
        }
        
        classDao.saveOrUpdate(newClass);
    }
}

class ClassDaoImpl implements IClassDao{
    void saveOrUpdate(Class class){
        try {
            this.hibernateTemplate.saveOrUpdate(class);
        } catch (DuplicateKeyException | NonUniqueObjectException e) {
            // 此处merge报出以上bug
            this.hibernateTemplate.merge(obj);
        }
    }
}

复制代码

以上的代码,在出现以下这种情况:

Class已存在,但是他关联的Student对象不存在

会报两个错:

  • A different object with the same identifier value was already associated with the session
  • No row with the given identifier exists

出现第一个问题是由于调用saveOrUpdate()时由于我们调用get方法时已查询过一次Class对象,但是我们更新时又是创建的新对象,所以会报错。

出现第二个问题的原因是因为我们捕获了第一个异常:NonUniqueObjectException,然后调用merge()方法,merge方法用于合并属性,当我们有一对多等关联配置时,他会去数据库查询相应的数据来进行数据合并,如果关联数据不存在就会出错。

举例:

id为1的Class 存在数据库中,此处数据库中还没有Student数据。我们通过业务更新ID为1的Class,同时新增一个Student对象。此时就会报错

解决办法为增加not-found配置:

注解方式:

class Class{
    @Id
    Long id;
    @OneToMany(cascade = CascadeType.DETACH,mappedBy = "clazz")
    @NotFound(action= NotFoundAction.IGNORE)
    List<Student> students;
}
复制代码

XML配置方式:

<class name="Class" table="class">
        <id column="id" name="id" type="java.lang.Long"><generator class="assigned" /></id>
        <bag name="students" cascade="none">
            <key>class_id</key>
            <one-to-many not-found="ignore" class="Student" />
        </bag>
</class>

复制代码

该参数默认为EXCEPTION,即找不到的话就会抛出异常。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

奇点临近

奇点临近

Ray Kurzweil / 董振华、李庆成 / 机械工业出版社 / 2011-10 / 69.00元

人工智能作为21世纪科技发展的最新成就,深刻揭示了科技发展为人类社会带来的巨大影响。本书结合求解智能问题的数据结构以及实现的算法,把人工智能的应用程序应用于实际环境中,并从社会和哲学、心理学以及神经生理学角度对人工智能进行了独特的讨论。本书提供了一个崭新的视角,展示了以人工智能为代表的科技现象作为一种“奇点”思潮,揭示了其在世界范围内所产生的广泛影响。本书全书分为以下几大部分:第一部分人工智能,第......一起来看看 《奇点临近》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具