如何加入仅获取选定的子实体与父实体
How to join fetch only selected children entities with parent entity
我正在尝试 select 仅通过 ID 将某些实体与父级一起。这可能吗?示例(省略样板):
class Parent {
int id;
List<Child> children;
}
class Child {
int id;
...
}
还有我的 JpaRepository:
interface ParentRepo extends JpaRepo<Parent,Integer> {
@Query("SELECT p FROM Parent p JOIN p.children c WHERE p.id = :parentId and c.id IN(:childIds")
Parent getParentByIdAndChildIds(int parentId, List<Integer> childIds)
}
我的期望是调用:
parentRepo.getParentByIdAndChildIds(1, Arrays.asList(1,2,3))
将 return 仅附加 3 个子实体的父对象,但我得到了所有子实体(即 ID 为 1-10 的子实体)。
这没有任何意义,因为需要获取整个实体图。考虑一个 parent p
有 children c1
, c2
和 c3
并且只有 c1
和 c2
传递给您的方法。如果您仅使用 c1
和 c2
获取 Parent
实体,那么如果您执行以下操作会发生什么:
p = parentRepo.getParentByIdAndChildIds(1, Arrays.asList(1,2));
p.getChildren().add(c3);
parentRepo.save(p); // what happens?
创建一个新的 child 没有意义,因为数据库中已经存在一个。另一方面,jpa 的默认行为会在保存时删除 p
和 c3
之间的关系而不修改:
p = parentRepo.getParentByIdAndChildIds(1, Arrays.asList(1,2));
parentRepo.save(p); // is the relationship between p and c3 destroyed
考虑创建双向关系(也从 Child
到 Parent
)并仅获取 Child
个实体(从 ChildRepository
):
interface ChildRepository extends JpaRepository<Child, Integer> {
@Query("SELECT c FROM Child c WHERE c.parent.id = :parentId and c.id IN(:childIds)")
List<Child> getParentByIdAndChildIds(int parentId, List<Integer> childIds)
}
这样你只会得到你想要的 Child
个实体,而且 Parent
可以从任何 Child
(children.get(0).getParent()
).
我正在尝试 select 仅通过 ID 将某些实体与父级一起。这可能吗?示例(省略样板):
class Parent {
int id;
List<Child> children;
}
class Child {
int id;
...
}
还有我的 JpaRepository:
interface ParentRepo extends JpaRepo<Parent,Integer> {
@Query("SELECT p FROM Parent p JOIN p.children c WHERE p.id = :parentId and c.id IN(:childIds")
Parent getParentByIdAndChildIds(int parentId, List<Integer> childIds)
}
我的期望是调用:
parentRepo.getParentByIdAndChildIds(1, Arrays.asList(1,2,3))
将 return 仅附加 3 个子实体的父对象,但我得到了所有子实体(即 ID 为 1-10 的子实体)。
这没有任何意义,因为需要获取整个实体图。考虑一个 parent p
有 children c1
, c2
和 c3
并且只有 c1
和 c2
传递给您的方法。如果您仅使用 c1
和 c2
获取 Parent
实体,那么如果您执行以下操作会发生什么:
p = parentRepo.getParentByIdAndChildIds(1, Arrays.asList(1,2));
p.getChildren().add(c3);
parentRepo.save(p); // what happens?
创建一个新的 child 没有意义,因为数据库中已经存在一个。另一方面,jpa 的默认行为会在保存时删除 p
和 c3
之间的关系而不修改:
p = parentRepo.getParentByIdAndChildIds(1, Arrays.asList(1,2));
parentRepo.save(p); // is the relationship between p and c3 destroyed
考虑创建双向关系(也从 Child
到 Parent
)并仅获取 Child
个实体(从 ChildRepository
):
interface ChildRepository extends JpaRepository<Child, Integer> {
@Query("SELECT c FROM Child c WHERE c.parent.id = :parentId and c.id IN(:childIds)")
List<Child> getParentByIdAndChildIds(int parentId, List<Integer> childIds)
}
这样你只会得到你想要的 Child
个实体,而且 Parent
可以从任何 Child
(children.get(0).getParent()
).