Hibernate:a different object with the same identifier value was already associated with the session
最近在项目中遇到这个异常,在网上查了很多资料,但是有一些问题,因此写下来做一个记录:
异常发生场景
这个异常通常发生在一个session 内对同一个数据库对象生成了多个(经常是load(id)/get(id)一个,又new+setId(id)一个),然后又对其进行了update()或者save() .从业务逻辑的角度,经常发生在修改/更新的操作中.
异常分析
session中已经存在一个与当前对象不同但是标识符相同的对象,原因是session忘记关闭,或忘记commit(),造成本该分为两个session的,合为了一个session,就出现了此异常.解决手段也很简单,通过session关闭和事务,把相同的操作对象从session级别或者事务级别上分隔开
网上的解决方案
解决方法一:session.clean()
PS:如果在clean操作后面又进行了saveOrUpdate(object)等改变数据状态的操作,有可能会报出”Found two representations of same collection”异常。
解决方法二:session.refresh(object)
PS:当object不是数据库中已有数据的对象的时候,不能使用session.refresh(object)因为该方法是从hibernate的session中去重新取object,如果session中没有这个对象,则会报错所以当你使用saveOrUpdate(object)之前还需要判断一下。
解决方法三:session.merge(object)
PS:Hibernate里面自带的方法,推荐使用。
实践解决方案
在经过实践之后我发现上面的三种解决方法都无效,主要没有从根本上解决问题,仍然报这个异常,其实只要注意在进行完Hibernate持久化操作之后关闭session就不会发生这个异常:
session.close();
或者在执行持久化操作之前先清空session:
session.clear();
都可以解决或避免这个异常!
经验分享!欢迎指正!不喜勿喷!