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

  • 相关阅读:
    sql之Replace
    虚拟主机的IIS连接数和访问流量限制各是什么
    SQL COUNT() 函数
    bzoj3163 Eden的新背包问题
    THUPC2018 城市地铁规划
    HNOI 2017 礼物
    NOI 模拟赛
    PKUSC2018 Slay The Spire
    NOI 模拟赛
    NOI 模拟赛
  • 原文地址:https://www.cnblogs.com/siashan/p/4277212.html
Copyright © 2011-2022 走看看