使用jpa存储库查询多个表

问题描述 投票:1回答:1

假设我有3个实体 - UserSkillsDepartment和我有相应的所有存储库 - UserRepositorySkillRepositoryDepartmentRepository

我知道应该在相应的实体类中指定实体之间的关系映射,即一对多。问题是我想在查询中使用所有3个实体。我该怎么办?单个存储库只与一个实体相关联吗?那么,我将如何/在哪里写它?

spring-boot spring-data spring-data-jpa jpql
1个回答
0
投票

由于有许多不同的方法可以使用Spring Data JPA指定查询,因此可以有各种答案。

  1. 也许你不必。如果实体A引用B,你只想用你的B得到As,你只需使用你的ARepository加载As并使用对象导航来获取你的Bs。您可以阅读有关如何控制此操作的更多信息。
  2. 如果要在where条件中引用实体,可以在查询方法名称中使用属性路径:https://docs.spring.io/spring-data/jpa/docs/current/reference/html/#repositories.query-methods.query-property-expressions
  3. 如果您正在使用@Query注释,您可以(几乎)使用JPQL执行任何操作。除此之外,您还可以导航属性以在where子句中使用它们。

通常,您将根据返回的主实体将该查询放在匹配的存储库中。

© www.soinside.com 2019 - 2024. All rights reserved.