org.hibernate.NonUniqueObjectException异常解决方法(2)

 异常:org.hibernate.NonUniqueObjectException: a different object with the same identifier value was already associated with the session
代码片段:
注:以下为session打开的状态
* 我手动构造了一个Photo对象
Photo photo=new Photo();
photo.setId(1);
*然后我用load加载同一ID的photo对象
Photo p=session.load(Photo.class,1);
现在一级缓存里已经有了id为1的p对象
*然后我执行删除photo对象
session.delete(photo);
当我直行这句删除的时候抛出了异常,为什么呢?
因为当我执行删除photo对象的时候,它会去先删除一级里找有没有这个photo的id的Photo的对象,这个photo是我手动创建的,它的id为1,那么好,它去一级缓存里刚好找到了为1的Photo类型的对象但是它引用的是p,不是photo,所以异常被抛出,这个异常的意思就是:有两个标识一样但不是同一个引用的对象了。所以它无法执行删除。
*改动代码
session.delete(p);
测试 通过。
如果你也遇到了同样的异常,不知所措,你可以用session.clean清一下缓存。呵呵。

org.hibernate.LazyInitializationException是一个在Hibernate中常见的异常。它表示在尝试访问延迟加载的属性或关联对象时,Hibernate会话已经关闭或不可用,导致无法初始化代理对象。 通常情况下,Hibernate会使用懒加载机制延迟加载关联对象。这意味着当你读取一个实体对象时,它的关联对象并不会立即加载,而是在需要访问关联对象时才会从数据库中加载。然而,如果在Session关闭后尝试访问延迟加载的属性或关联对象,就会抛出org.hibernate.LazyInitializationException异常解决org.hibernate.LazyInitializationException方法有几种: 1. 保持会话打开:一种常见的解决方法是在访问延迟加载属性或关联对象之前保持Hibernate会话打开状态。这可以通过在事务中延长会话的生命周期或者在需要时重新加载实体对象来实现。这样做的目的是确保在访问延迟加载属性或关联对象时,会话仍然有效。 2. 使用Eager加载:可以将关联对象的加载方式从延迟加载改为立即加载(Eager加载)。这样做可以在加载实体对象时同时将关联对象一起加载,避免在访问时出现LazyInitializationException异常。但需要注意的是,如果关联对象的数据量很大或者关联对象之间存在循环引用,使用Eager加载可能会导致性能问题。 3. 手动初始化关联对象:在某些情况下,你可以在Hibernate会话仍然打开时手动初始化延迟加载的关联对象,以避免LazyInitializationException异常。你可以通过调用关联对象的getter方法或使用Hibernate.initialize()方法来实现。 需要根据具体情况选择合适的解决方法。如果你在使用Hibernate时遇到了org.hibernate.LazyInitializationException异常,可以根据上述方法尝试解决异常
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值