环境
JBoss 6.0 + MyEclipse 8.6 + MySQL 5.1 + Struts 2.3 + EJB 3.0
问题
两张表存在多对一的关系,数据不能正常显示,当执行查询时出现如下异常:
org.hibernate.LazyInitializationException: could not initialize proxy - no Session
解决
将ManyToOne的fetch方式由LAZY改为EAGER。
@ManyToOne(fetch = FetchType.EAGER)
@ManyToOne(fetch = FetchType.LAZY)
@ManyToOne(fetch = FetchType.EAGER)
@JoinColumn(name = "TB_STUDENT_id", nullable = false)
public TbStudent getTbStudent() {
return this.tbStudent;
}
知识拓展
如果是EAGER,那么表示取出这条数据时,它关联的数据也同时取出放入内存中。
如果是LAZY,那么取出这条数据时,它关联的数据并不取出来,在同一个session中,什么时候要用,就什么时候取(再次访问数据库)。
但是,在session外,就不能再取了。用EAGER时,因为在内存里,所以在session外也可以取。
参考资料
http://blog.csdn.net/remote_roamer/article/details/2934437
http://xiyuansanlian.iteye.com/blog/1560287
@Wentasy 博文仅供参考,欢迎大家来访。如有错误之处,希望批评指正。原创博文如需转载请注明出处,谢谢 :) [CSDN博客] |