java - 如何将仅获取选定的子实体与父实体连接起来

标签 java spring jpa spring-data jpql

我试图通过 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 的子实体)。

最佳答案

这没有任何意义,因为需要获取整个实体图。考虑一位家长p有 child c1 , c2c3并且只有 c1 的 ID和c2被传递给你的方法。如果你获取 Parent实体 c1c2只是,如果你这样做,会发生什么:

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

创建一个新的子项没有意义,因为数据库中已经存在一个子项。另一方面,jpa 的默认行为会删除 p 之间的关系。和c3保存时不修改:

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())。

关于java - 如何将仅获取选定的子实体与父实体连接起来,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60941535/

相关文章:

java - 使用 JDK Logging 查找实际打开的日志文件

java - 通过套接字发送多个变量?

java - 使用 XML 配置禁用 Websocket 中的 CSRF 保护

java - Spring Data JPA – 自定义 native 查询方法列表打印 java.lang.Object

java - 什么是 NullPointerException,我该如何解决?

java - 在 java 中使用 itext 生成 html 到 pdf

java - Spring发送和获取文件的正确方式

java - Spring FTP 入站与出站 channel 适配器

java - 使用 JPA 2 和 Hibernate 的 Google Cloud Dataflow 应用程序无法与 BlockingDataflowPipelineRunner 一起运行。找不到 persistence.xml

java - 使用 AccessType.PROPERTY 对 JPA 实体属性调用清除失败