您的位置:首页 > 编程语言 > Java开发

spring data jpa session 查询时 session 已经关闭问题

2017-06-15 10:20 501 查看
前提:首先我的项目架构,采用的是spring boot + jpa 实现的。因此模型之间的关系就不得不采用 一对多,和多对一等关系来标识。情景:一对多情况,我一个老师,和 多个学生,因此在 老师模型中建立了OneToMany关系,
@OneToMany(mappedBy = "teacher")
private Set<Student> studentSet;//学生集合
当我在进行单元测试查询老师时,并带出学生的集合时,报出异常:
@Test
public void query()
{
Teacher teacher = xxxDao.queryById(1);
teacher.getStudentSet();
}
org.hibernate.LazyInitializationException: failed to lazily initialize a collection of role...
could not initialize proxy - no Session...
解决办法:
由于引用的是spring boot,所以只需要在配置文件中,加上
spring.jpa.open-in-view: true,并且在调用的方法上 加上事物注解 @Tractional 即可
(这里不得不强调,spring boot的强大之处,原本需要加载很多依赖文件和XML中的配置,如今spring boot 自动帮我需要的都注入了)
原因:
由于使用jpa建立关系映射时,默认的都是 懒加载,只有当我们用到了,再去查询,因此,查询依赖的集合属性时,session 已经关闭,
加上
spring.jpa.open-in-view: true的意思是1.session 会在 此次request 的Thread 中结束后,就会关闭2.如果到了view 层,filter会自动关闭session这里涉及到jpa session 问题,大家可以具体搜索相关资料进行研究

                                            
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  spring session jpa