懒加载异常解决办法

最近在做一个如图功能时加载数据就报ERROR DefaultDispatcherErrorHandler:42 - Exception occurred during processing request: org.hibernate

 

 

 

加载树形结构,使用关闭懒加载fetch=FetchType.EAGER

在数据库中取值的时候,如果使用懒加载,就会只取出一层节点的数据,然后关闭session,这样再去取下一层级的数据的时候就会报出错误:session is closed

如果是EAGER,那么表示取出这条数据时,它关联的数据也同时取出放入内存中

如果是LAZY,那么取出这条数据时,它关联的数据并不取出来,在同一个session中,什么时候要用,就什么时候取(再次访问数据库)。

但是,在session外,就不能再取了。用EAGER时,因为在内存里,所以在session外也可以取。

加了上面的fetch=FetchType.EAGER,表示立即加载后终于查询数据了 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值