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

来源:互联网 发布:淘宝福袋的衣服能买吗 编辑:程序博客网 时间:2024/05/21 06:45

前提:首先我的项目架构,采用的是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 问题,大家可以具体搜索相关资料进行研究

阅读全文
1 0
原创粉丝点击