我在使用 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 的情况下解析结果。
添加回答
举报
0/150
提交
取消