`
xly1981
  • 浏览: 143380 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

出现 already associated with the session问题后发现的相关信息

阅读更多
工程中存在报错a different object with the same identifier value was already associated with the session
研究过程中发现
1.保存对象失败
2.事务没有回滚

源码:
equipmentDao.delGroupInfoDtls(delList);//成功执行
equipmentDao.saveGroupInfoDtlList(addList);//执行失败,不确定异常是否和a different object with the same identifier value was already associated with the session 有关。

保存失败:
怀疑原因
典型原因

事务没有回滚
怀疑原因
1.因为抛出的异常不是RuntimException类型,所有没有执行回滚
2.因为struts-config.xml文件也出现了配置的问题,导致OpenSessioInView失效

来源http://blog.sina.com.cn/s/blog_5ca9fdd80100ffor.html
Hibernate 疑难异常及处理
1、a different object with the same identifier value was already associated with the session。
  错误原因:在hibernate中同一个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里面自带的方法,推荐使用。
2、Found two representations of same collection
  错误原因:见1。
  解决方法:session.merge(object)
以上两中异常经常出现在一对多映射和多对多映射中
a different object with the same identifier value was already associated with the session
一个经典的hibernate错误:a different object with the same identifier value was already associated with the session xxxx
hibernate3.0以上使用merge()来合并两个session中的同一对象

http://www.iteye.com/topic/15057?page=1
我原来用struts/spring/hibernate的时候同样使用OpenSessionInView,但是似乎没有robbin所说的问题啊。而且我在使用的时候,是ContextLoaderListener和ContextLoaderPlugIn一起用的。整个配置如下:
1.首先是web.xml
Java代码
<filter>  
       <filter-name>OpenSessionInViewFilter</filter-name>  
       <filter-class>org.springframework.orm.hibernate.support.OpenSessionInViewFilter</filter-class>  
   </filter>  
     
   <filter-mapping>  
       <filter-name>OpenSessionInViewFilter</filter-name>  
       <url-pattern>/*</url-pattern>  
   </filter-mapping>  
     
   <listener>  
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>  
</listener>  
 
..... 

<filter>
        <filter-name>OpenSessionInViewFilter</filter-name>
        <filter-class>org.springframework.orm.hibernate.support.OpenSessionInViewFilter</filter-class>
    </filter>
   
    <filter-mapping>
        <filter-name>OpenSessionInViewFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
   
    <listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>

......


2. 然后是struts-config.xml:
Java代码
<plug-in className="org.springframework.web.struts.ContextLoaderPlugIn">  
    <set-property property="contextConfigLocation"   
                  value="/WEB-INF/action-servlet.xml"   
    />  
</plug-in> 

<plug-in className="org.springframework.web.struts.ContextLoaderPlugIn">
<set-property property="contextConfigLocation"
  value="/WEB-INF/action-servlet.xml"
/>
</plug-in>

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics