【问题标题】:How to join fetch only selected children entities with parent entity如何加入仅获取选定的子实体与父实体
【发布时间】:2020-07-11 11:17:16
【问题描述】:

我试图通过 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))

将返回仅附加 3 个子实体的父对象,但相反,我得到所有子实体(即 ID 为 1-10 的子实体)。

【问题讨论】:

    标签: java spring jpa spring-data jpql


    【解决方案1】:

    这没有任何意义,因为需要获取整个实体图。考虑一个父母p 有孩子c1c2c3,并且只有c1c2 的ID 被传递给您的方法。如果您仅使用 c1c2 获取 Parent 实体,那么如果您执行以下操作会发生什么:

    p = parentRepo.getParentByIdAndChildIds(1, Arrays.asList(1,2));
    p.getChildren().add(c3);
    parentRepo.save(p); // what happens?
    

    创建一个新的孩子没有意义,因为数据库中已经存在一个。另一方面,jpa 的默认行为会在不修改的情况下保存pc3 之间的关系:

    p = parentRepo.getParentByIdAndChildIds(1, Arrays.asList(1,2));
    parentRepo.save(p); // is the relationship between p and c3 destroyed
    

    考虑创建双向关系(也从ChildParent)并仅获取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()) 访问。

    【讨论】:

    • 好的,谢谢。说得通。需要自下而上,而不是自上而下-> 下。
    • @OgnjenMišić,祝你有美好的一天!
    猜你喜欢
    • 1970-01-01
    • 2017-09-27
    • 2023-03-19
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-01-18
    相关资源
    最近更新 更多