当前位置: 首页 > 知识库问答 >
问题:

如何在Spring控制器中获取FetchType.lazy与JPA和Hibernate的关联

沈俊美
2023-03-14

我有一个Person类:

@Entity
public class Person {

    @Id
    @GeneratedValue
    private Long id;

    @ManyToMany(fetch = FetchType.LAZY)
    private List<Role> roles;
    // etc
}

多对多关系是懒惰的。

在我的控制器中

@Controller
@RequestMapping("/person")
public class PersonController {
    @Autowired
    PersonRepository personRepository;

    @RequestMapping("/get")
    public @ResponseBody Person getPerson() {
        Person person = personRepository.findOne(1L);
        return person;
    }
}
public interface PersonRepository extends JpaRepository<Person, Long> {
}

我的XML描述,以备所需。

多谢了。

共有1个答案

姬银龙
2023-03-14

您必须对惰性集合进行显式调用才能初始化它(通常的做法是为此目的调用.size())。在Hibernate中,有一个专门的方法(Hibernate.initialize()),但JPA没有类似的方法。当然,当会话仍然可用时,您必须确保调用已经完成,因此使用@transactional注释您的controller方法。另一种方法是在控制器和存储库之间创建一个中间服务层,它可以公开初始化惰性集合的方法。

请注意,上面的解决方案很简单,但会导致对数据库的两个不同的查询(一个针对用户,另一个针对其角色)。如果希望获得更好的性能,请将以下方法添加到Spring Data JPA存储库接口中:

public interface PersonRepository extends JpaRepository<Person, Long> {

    @Query("SELECT p FROM Person p JOIN FETCH p.roles WHERE p.id = (:id)")
    public Person findByIdAndFetchRolesEagerly(@Param("id") Long id);

}

此方法将使用JPQL的fetch join子句在到数据库的一次往返中急切地加载角色关联,因此将减轻上述解决方案中两个不同查询所引起的性能损失。

 类似资料:
  • 问题内容: 我有一个Person类: 与多对多的关系是懒惰的。 在我的控制器中 而PersonRepository只是此代码,是根据本指南编写的 但是,在此控制器中, 我实际上需要惰性数据。 如何触发加载? 尝试访问它将会失败 无法延迟初始化角色集合:no.dusken.momus.model.Person.roles,无法初始化代理-没有会话 或其他例外情况,具体取决于我的尝试。 我的xml-

  • 问题内容: 我有一个Person类: 与多对多的关系是懒惰的。 在我的控制器中 而PersonRepository只是此代码. 但是,在此控制器中,我实际上需要惰性数据。如何触发加载? 尝试访问它将会失败 无法延迟初始化角色集合:no.dusken.momus.model.Person.roles,无法初始化代理-没有会话 或其他例外情况,具体取决于我的尝试。 我的xml-description,

  • //TestController。Java语言 有人能告诉我这是从SpringMVCRest控制器中的“Request.set实体”获取数据的正确方法吗? 其次,在邮递员“httpPost”请求中,我传递参数(testKey 第三,在不知道httpPost请求中的参数的情况下,我能否在Spring控制器中解析传入请求并从中提取参数?

  • 如果运行在负载均衡器之后,最好应该理解头。因此,在本例中,我想让类似于。如果需要的话,我将使用Netty服务器实现。

  • Dao类看起来像:- 和app.java类: 包结构类似于:[1]:https://i.stack.imgur.com/sbz24.jpg application.properties文件内容:-

  • 问题内容: 我需要控制器中的应用程序上下文路径,我尝试了下面的代码抛出NULLPOINTER EXCEPTION。 HttpServletRequest请求; 字符串路径= request.getContextPath(); 请帮我 谢谢 问题答案: 变量已声明,但未初始化。难怪你得到一个。 查看文档以访问与请求相关的其他数据。 读完这些并确定要将代码绑定到本机Servlet API后,请尝试以下