关于Hibernate性能优化之 FetchType=Lazy时查询数据

当表A和表B一对多的关系

对于A和B的实体类,设置FetchType=EAGER时,取A表数据,对应B表的数据都会跟着一起加载,优点不用进行二次查询。缺点是严重影响数据查询的访问时间。

解决办法FetchType=LAZY,此时查询的访问时间大大缩短,缺点是查询表A 的数据时,访问不到表B的数据。

解决办法尝试一,在web.xml中加入下面配置,表示在页面中关闭session

<!-- 把session的关闭延迟到jsp页面显示之后,在配在struts2上面。-->
    <filter>
        <filter-name>OpenSessionInView</filter-name>
        <filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>OpenSessionInView</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
出现的问题是:新增加一条记录回到列表页面,对应的B表数据还是没有。
解决办法尝试二:
在session未关闭前循环List,显示调用,举例如下
for(B b:bList){
    b.getA();
}
出现问题:如果debug模式,可以获得A信息,如果tomcat正常运行模式,还是取不到A。没有具体研究是不是因为我们实在ManyToOne多的端取一端。
解决办法三:此办法可以应用
for(B b:bList){
   Hibernate.initialize( b.getA());
}
解决办法四:此办法也可以应用
在session关闭后,我可以循环
for(B b:bList){
   int aId = b.getA().getId();
  A a =  findAById(aId);
  b.setA(a);
}


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值