在目前我遇到出现延迟加载异常已经遇到两种情况了,在这里总结一下给大家。
1.Hibernate的session关闭问题
案例:在OA中,service层有事务,所以会在service层开启事务和关闭事务,但是部门与上级部门有关联关系,出现懒加载,在用到的时候才会加载上级部门名称,我们在界面上才会用到上级部门名称,这时候出现了懒加载异常情况,因为在用到的时候已经关闭session了。
抛出异常:could notinitialize proxy - the owning Session was closed
解决方法:
(1)在web.xml中配置openSessionInViewFilter这个过滤器,过滤所有的*.action。
这种方法,让session关闭延迟在界面层才关闭。这样在界面取数据的时候就不会报错啦。
<!-- 配置Spring的用于解决懒加载问题的过滤器 -->
<filter>
<filter-name>OpenSessionInViewFilter</filter-name>
<filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>OpenSessionInViewFilter</filter-name>
<url-pattern>*.action</url-pattern>
</filter-mapping>
(2)去除延迟加载的属性,设置为lazy="false"。关闭延迟加载。
(3)采取的操作Hibernate.initialize()方法,强制加载某属性。
2.动态代理类属性过滤问题
案例:在做车段子的那个项目的时候,因为要跟Android和IOS提供数据,所以在后台查询出数据需要转换成JSON,这时候就开始报错。。。
出现原因:
由于延迟加载获得的对象,并不是我们自己写的类型,而是由cglib字节码生成器生成的动态代理类型,在这个子类中又添加了新的属性,所以当通过json lib转换时,会抛出异常:java.sql.SQLException:Positioned Update not supported
解决方法:将cglib中添加的属性过滤掉
JsonConfigjsonConfig=new JsonConfig();
jsonConfig.setExcludes(newString[]{"handler","hibernateLazyInitializer"});
JSONArray arvert = JSONArray.fromObject(实体集合,jsonConfig);
json = arvert.toString();
年前,有人问我,遇到过延迟加载问题吗,我说遇到过,让我讲讲。。我一时还说不出来,正好有空了总结一下。有时候不能一直往前跑,停下脚步,喝杯茶,总结一下。