昨天总是抛出这个异常,想想最简单的方法估计就是把fetch设置为FetchType.EAGER,可这未免也太影响了效率,在网上上尝试了几种方法人们都建议把fetch 设为 FetchType.EAGER,或者通过在web.xml中设置OpenSessionInViewFilter,结果都不凑效,在同事的指导下发现用fetch可以解决这一难题。这就是fetch的功能。我们可以把fetch与lazy="true"的关系类比为事务当中的编程式事务与声明式事务。
错误的hql语句
加入fetch以后
错误的hql语句
SELECT bioChemicalInfo FROM BioChemicalInfo AS bioChemicalInfo LEFT JOIN bioChemicalInfo.experiment AS experiment LEFT JOIN experiment.experimentProcesses experimentProcess LEFT JOIN experimentProcess.experimentProcessRecords
加入fetch以后
SELECT bioChemicalInfo FROM BioChemicalInfo AS bioChemicalInfo LEFT JOIN [color=blue]FETCH [/color]bioChemicalInfo.experiment AS experiment LEFT JOIN FETCH experiment.experimentProcesses experimentProcess LEFT JOIN FETCH experimentProcess.experimentProcessRecords
本文介绍了在使用Hibernate框架时遇到的懒加载异常问题,并提供了解决方案。通过调整fetch策略,将fetch设置为FetchType.EAGER,成功解决了异常。同时对比了fetch与lazy属性的区别,类似于事务中的编程式事务与声明式事务的区别。
845

被折叠的 条评论
为什么被折叠?



