Springboot集成jpa出现no Session异常原因与解决方法
查询班级中的学生信息
@Test
public void testFindCla(){
//查询所有的班级信息
List<Clazz> clazzes = clazzDao.findAll();
for(Clazz clazz:clazzes){
// System.out.println(clazz.getCid()+", "+clazz.getCname());
List<Student> students = clazz.getList();
for(Student student:students){
System.out.println(student);
}
System.out.println(clazz.getCid()+", "+clazz.getCname());
}
}
原因
(1)查询班级信息,当班级信息查询完毕,dao层结束后,session就会关闭
(2)再次调用dao层的方法查询student信息,此时就会没有session对象,所以出现一个no Session异常
解决方法
(1)设置立即加载 @OneToMany(mappedBy = "clz",fetch = FetchType.EAGER)//mapperBy 创建一和多的映射关系,值是对方的属性名称
(2)延长session的生命周期
懒加载
比如查询班级信息:
select * from t_clazz clazz0_
查询班级信息,并没有查询班级中学生的信息
懒加载:查询班级信息并没有发送select语句查询班级当中的学生信息,这样的查询就是懒加载查询
只有当使用到学生信息的时候,才会发送select查询学生信息
立即加载
立即加载:查询班级信息立即发送select语句查询学生信息
总结:
一般针对一对多查询,如果查询一的一方,不需要立即加载。性能降低,建议使用默认值
就拿班级信息和学生信息,一个班级有许多学生,一的一方就指的是班级