为了账号安全,请及时绑定邮箱和手机立即绑定

如何在 Criteria API / JPQL 中使用具有一对多属性的 JPA 投影

如何在 Criteria API / JPQL 中使用具有一对多属性的 JPA 投影

慕码人8056858 2022-12-21 12:58:23
我在使用 Criteria API 创建查询时遇到困难,该查询投射被查询实体的属性并实例化 DTO。其中一个投影属性映射了与另一个实体的一对多关系,因此它是一组依赖实体。我正在使用 fetch join 来检索集合。但我收到以下错误:org.hibernate.QueryException: query specified join fetching, but the owner of the fetched association was not present in the select list我已经尝试使用常规连接,但在这种情况下,不会填充依赖实体集。完全删除连接和/或提取也无济于事。我正在使用 JPA 规范 2.0、Hibernate 4.2.21.Final、Spring Data JPA 1.10.11.RELEASE。有人可以就此给我建议吗?我也会为一个工作的 JPQL 感到高兴。这是我的查询实现:@Overridepublic List<EntityADto> findByPartialKey1OrderByPartialKey2(String partialKey1) {    // Create query    final CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();    final CriteriaQuery<EntityADto> criteriaQuery = criteriaBuilder.createQuery(EntityADto.class);    // Define FROM clause    final Root<EntityA> root = criteriaQuery.from(EntityA.class);    root.fetch(EntityA_.oneToManyAttribute);    // Define DTO projection    criteriaQuery            .select(criteriaBuilder.construct(                    EntityADto.class,                    root.get(EntityA_.id).get(EntityAId_.partialKey1),                    root.get(EntityA_.id).get(EntityAId_.partialKey2),                    root.get(EntityA_.stringAttribute1),                    root.get(EntityA_.stringAttribute2),                    root.get(EntityA_.oneToManyAttribute)))            .orderBy(criteriaBuilder.asc(root.get(EntityA_.id).get(EntityAId_.partialKey2)))            .distinct(true);    // Define WHERE clause    final ParameterExpression<String> parameterPartialKey1 = criteriaBuilder.parameter(String.class);    criteriaQuery.where(criteriaBuilder.equal(root.get(EntityA_.id).get(EntityAId_.partialKey1), parameterPartialKey1));    // Execute query    final TypedQuery<EntityADto> typedQuery = entityManager.createQuery(criteriaQuery);    typedQuery.setParameter(parameterPartialKey1, partialKey1);    return typedQuery.getResultList();}
查看完整描述

1 回答

?
动漫人物

TA贡献1815条经验 获得超10个赞

连接为您提供 sql 中的行结果集合:


Parent    Child

p1        c1

p1        c2

p1        c3

等等。没有将生成的集合传递给构造函数的机制。


JPA 规范 4.14


constructor_expression ::=

NEW constructor_name ( constructor_item {, constructor_item}* )


constructor_item ::=

single_valued_path_expression |

scalar_expression |

aggregate_expression |

identification_variable

此外,另一个问题是您的查询可能会返回多个父项或子项。


Parent    Child    Child2

p1        c111     c121

p1        c121     

p1        c131     c122

p2        c211     c211

p2        c221     c212

p2        c231     

我猜这是因为对于底层 JPA 提供者来说,它变得太复杂了,以至于不知道在哪里拆分它,或者使用哪些值来传递给子构造函数,或者可能是我不熟悉的更微妙的原因。最重要的是,它要求您提供用于解析此矩阵的代码,如果您打算这样做,您也可以在没有 JPA 的情况下解析结果。


查看完整回答
反对 回复 2022-12-21
  • 1 回答
  • 0 关注
  • 83 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信