博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
org.hibernate.ObjectNotFoundException: No row with the given identifier exists
阅读量:6643 次
发布时间:2019-06-25

本文共 692 字,大约阅读时间需要 2 分钟。

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

转载于:https://www.cnblogs.com/siashan/p/4277212.html

你可能感兴趣的文章
EF Core 2.1 Raw SQL Queries (转自MSDN)
查看>>
XIX Open Cup named after E.V. Pankratiev. GP of Poland(AMPPZ-2018)
查看>>
高频交易系统
查看>>
face recognition[Euclidean-distance-based loss][Center Face]
查看>>
WPF的逻辑树与视觉树(1)基本概念
查看>>
IdentityServer Topics(6)- Windows身份验证
查看>>
(原創) 解决问题时,不要只从演算法的角度去思考 (日記)
查看>>
论操作系统对双核和多路CPU的支持
查看>>
使用Webbrowser的一点心得体会
查看>>
(筆記) 如何在Linux上使用Verilog PLI? (SOC) (Verilog PLI) (NC-Verilog) (Linux)
查看>>
五个故事说穿了很多人
查看>>
OpenGL3D图形绘制
查看>>
3D成像法:抖动
查看>>
Azure China (13) Azure China CDN经验总结
查看>>
用dynamic增强C#泛型表达力
查看>>
Windows Phone 7.1 Mango ROM 安装指南
查看>>
[转] 百万级数据查询优化
查看>>
POJ 3294 Life Forms (后缀数组)
查看>>
POJ 3228 Gold Transportation (二分+最大流) (Dinic + 二分 或 EK)
查看>>
Entity Framework ObjectContext IUnitOfWork
查看>>