zoukankan      html  css  js  c++  java
  • 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就采用默认的抛出异常来处理了。经常出现显示一个项目的列表时没有数据。

  • 相关阅读:
    Oracle使用sys登录时报错ORA-28009解决方法
    oem的使用
    isqlplus的使用
    oracle客户端中文乱码问题的解决
    十:jinja2模板查找路径
    九:flask-response响应
    八:flask-重定向示例
    七:flask-一些小细节
    六:flask-自定义URL转换器
    五:flask-url_for使用详解
  • 原文地址:https://www.cnblogs.com/siashan/p/4277212.html
Copyright © 2011-2022 走看看