Hibernate延迟加载问题-阿里云开发者社区

开发者社区> 数据库> 正文

Hibernate延迟加载问题

简介:   Hibernate延迟加载是项目中非常常用的技术。通过使用Hibernate延迟加载机制可以在加载数据是不必加载全部数据,而是只加载我们需要的那部分,其余部分在需要使用时才从数据库装载,以此来减少数据量提高系统性能。

  Hibernate延迟加载是项目中非常常用的技术。通过使用Hibernate延迟加载机制可以在加载数据是不必加载全部数据,而是只加载我们需要的那部分,其余部分在需要使用时才从数据库装载,以此来减少数据量提高系统性能。

  Hibernate延迟加载大致可以分为两类,一类是延迟属性加载,另一类是延迟关联实体加载。

属性加载

  属性加载又可以分为两类,一类是集合属性,一类是非集合属性。

关联加载

  关联加载也分两种情况,一种是多对一,另一种是一对一。

  今天遇到的问题属于关联加载的,A、B部门属于关联部门,B属于A的子部门,当查询B部门的时候并没有用的A部门的相关属性,所以为了保证性能我们并没有将A部门的信息加载到页面。但是当我们在B部门页面点击”返回上一级“按钮是,需要传入一个A部门的ID,这时候B部门信息已经显示到页面,相关的session已经关闭了,系统会抛出异常,错误信息如下:

  

解决办法:

(1)将延迟加载属性设置为false

  

  这种方法最简单,但是这样我们就不能用hibernate的延迟加载机制了,也就是说每次加载都有可能加载很多用不到的数据,影响系统性能,这是不推荐的。

(2)在web.xml中配置openSessionInViewFilter这个过滤器,必须将openSessionInViewFilter过滤器配置中Struts2核心过滤器之前。

<!-- 配置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>  
  
  过滤所有的*.action。这种方法,让session关闭延迟在界面层才关闭。这样在界面取数据的时候就不会报错啦。

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
数据库
使用钉钉扫一扫加入圈子
+ 订阅

分享数据库前沿,解构实战干货,推动数据库技术变革

其他文章