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清一下缓存。呵呵。