懒加载异常解决办法

最近在做一个如图功能时加载数据就报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,表示立即加载后终于查询数据了 

猜你喜欢

转载自blog.csdn.net/luo609630199/article/details/81320065
今日推荐