首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >尝试延迟加载和返回带有@transactional注释的方法中的列表,但得到一个no session错误

尝试延迟加载和返回带有@transactional注释的方法中的列表,但得到一个no session错误
EN

Stack Overflow用户
提问于 2021-09-03 09:44:21
回答 2查看 32关注 0票数 0

这是可行的,但是当我尝试删除courses.size时,我没有得到会话错误。

代码语言:javascript
复制
@Transactional
public List<Course> initiateCourses(Long id) {
    Instructor instructor = instructorRepository.findById(2L).get();
    List<Course> courses = instructor.getCourses();
    courses.size();
    return courses;
}

它起作用了,但感觉像个黑客。

此外,我还发现了另一种加载惰性集合的方法。

代码语言:javascript
复制
@Repository
public interface InstructorRepository extends CrudRepository<Instructor, Long> {
    @Query("SELECT p FROM Instructor p LEFT JOIN FETCH p.courses WHERE p.id = ?1")
    Optional<Instructor> findByIdAndFetchCourseEagerly(Long id);
}

我应该使用性能明智的哪一个?或者有没有更好的方法来获取惰性初始化对象。

EN

回答 2

Stack Overflow用户

发布于 2021-09-03 09:56:26

您可以使用@EntityGraph指定应获取对象层次结构的哪些部分:

代码语言:javascript
复制
@Repository
public interface InstructorRepository extends CrudRepository<Instructor, Long> {

    @EntityGraph(type = EntityGraphType.FETCH, attributePaths = {"courses"})
    Optional<Instructor> findById(Long id);
}

请参阅:EntityGraph (Spring Data JPA)

票数 0
EN

Stack Overflow用户

发布于 2021-09-03 10:10:21

在您从中检索元素或调用size()方法之前,不会初始化此代理。有几种方法可以在不使用“魔法”的情况下解决问题:

  1. 显式调用Hibernate.init(),并在从方法返回它之前将其传递给您的集合代理。
  2. 按照Peter Walser的建议使用实体图
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69042830

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档