微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

org.hibernate.hql.internal.ast.QuerySyntaxException:无效的路径:JPQL自定义查询中的“ e.id”

如何解决org.hibernate.hql.internal.ast.QuerySyntaxException:无效的路径:JPQL自定义查询中的“ e.id”

我可以尝试从子查询获取计数,然后将e.id显示为无效路径。我的查询复杂,这就是为什么我陷入其中。如何解决这个错误,任何人都对此有想法。

我正在使用带有jpa存储库的spring boot。使用@Query注释将查询写入存储库。我尝试使用UNION,但无法在JPA,JPQL查询支持。那么使用JPQL定制查询解决方案是什么。我在查询中使用了构造函数,因为我想在每行中添加3种类型的计数。这就是为什么我采用基于构造函数查询

1.DTO

package com.techavidus.networkingPhoniex.responseDTO;

import lombok.*;

@ToString
@NoArgsConstructor
@AllArgsConstructor
@Builder
public @Data
class ManageGroupsDTO {

    private Long group_id;

    private String group_name;

    private Long groupTypeId;

    private String groupTypeName;

    private Long countUpcomingEvents;

    private Long countPastEvents;

    private Long countFollows;

    private String groupStates;
}

2。查询

@Repository
public interface GroupsDao extends JpaRepository<Groups,Long> {

   @Query("SELECT new com.techavidus.networkingPhoniex.responseDTO.ManageGroupsDTO(g.group_id," +
            "g.group_name,gt.group_type_id,gt.name,COUNT(e.id),COUNT(ee.id),COUNT(mgf.id),gs.name) " +
            "FROM Groups g LEFT JOIN MemberFollowGroups mgf LEFT JOIN mgf.groups gf ON gf.group_id = g.group_id " +
            "JOIN g.groupTypes gt LEFT JOIN g.primary_contact_member_id pm " +
            "LEFT JOIN g.secondary_contact_member_id sm LEFT JOIN g.groupStates gs " +
            "WHERE (pm.member_id=:memberId OR sm.member_id=:memberId) IN " +
            "(SELECT e FROM Events e LEFT JOIN e.eventRecurrence er LEFT JOIN e.groups eg ON eg.group_id = g.group_id WHERE e.startDate >=:todayDate) AND " +
            "(SELECT ee FROM Events ee LEFT JOIN ee.eventRecurrence er LEFT JOIN ee.groups eg ON eg.group_id = g.group_id WHERE ee.startDate <:todayDate) " +
            "GROUP BY g.group_id")
    List<ManageGroupsDTO> manageMyGroupList(LocalDate todayDate,Long memberId);
}

3。错误

Caused by: java.lang.IllegalArgumentException: Validation Failed for query for method public abstract java.util.List com.techavidus.networkingPhoniex.dao.GroupsDao.manageMyGroupList(java.time.LocalDate,java.lang.Long)!
    at org.springframework.data.jpa.repository.query.SimpleJpaQuery.validateQuery(SimpleJpaQuery.java:93) ~[spring-data-jpa-2.2.4.RELEASE.jar:2.2.4.RELEASE]
    at org.springframework.data.jpa.repository.query.SimpleJpaQuery.<init>(SimpleJpaQuery.java:63) ~[spring-data-jpa-2.2.4.RELEASE.jar:2.2.4.RELEASE]
    at org.springframework.data.jpa.repository.query.JpaQueryFactory.fromMethodWithQueryString(JpaQueryFactory.java:76) ~[spring-data-jpa-2.2.4.RELEASE.jar:2.2.4.RELEASE]
    at org.springframework.data.jpa.repository.query.JpaQueryFactory.fromQueryAnnotation(JpaQueryFactory.java:56) ~[spring-data-jpa-2.2.4.RELEASE.jar:2.2.4.RELEASE]
    at org.springframework.data.jpa.repository.query.JpaQueryLookupStrategy$DeclaredQueryLookupStrategy.resolveQuery(JpaQueryLookupStrategy.java:140) ~[spring-data-jpa-2.2.4.RELEASE.jar:2.2.4.RELEASE]
    at org.springframework.data.jpa.repository.query.JpaQueryLookupStrategy$CreateIfNotFoundQueryLookupStrategy.resolveQuery(JpaQueryLookupStrategy.java:207) ~[spring-data-jpa-2.2.4.RELEASE.jar:2.2.4.RELEASE]
    at org.springframework.data.jpa.repository.query.JpaQueryLookupStrategy$AbstractQueryLookupStrategy.resolveQuery(JpaQueryLookupStrategy.java:78) ~[spring-data-jpa-2.2.4.RELEASE.jar:2.2.4.RELEASE]
    at org.springframework.data.repository.core.support.RepositoryFactorySupport$QueryExecutorMethodInterceptor.lookupQuery(RepositoryFactorySupport.java:574) ~[spring-data-commons-2.2.4.RELEASE.jar:2.2.4.RELEASE]
    at org.springframework.data.repository.core.support.RepositoryFactorySupport$QueryExecutorMethodInterceptor.lambda$mapMethodsToQuery$1(RepositoryFactorySupport.java:567) ~[spring-data-commons-2.2.4.RELEASE.jar:2.2.4.RELEASE]
    at java.util.stream.ReferencePipeline$3$1.accept(ReferencePipeline.java:193) ~[na:1.8.0_241]
    at java.util.Iterator.forEachRemaining(Iterator.java:116) ~[na:1.8.0_241]
    at java.util.Collections$UnmodifiableCollection$1.forEachRemaining(Collections.java:1051) ~[na:1.8.0_241]
    at java.util.Spliterators$IteratorSpliterator.forEachRemaining(Spliterators.java:1801) ~[na:1.8.0_241]
    at java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:482) ~[na:1.8.0_241]
    at java.util.stream.AbstractPipeline.wrapAndcopyInto(AbstractPipeline.java:472) ~[na:1.8.0_241]
    at java.util.stream.ReduceOps$ReduceOp.evaluateSequential(ReduceOps.java:708) ~[na:1.8.0_241]
    at java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234) ~[na:1.8.0_241]
    at java.util.stream.ReferencePipeline.collect(ReferencePipeline.java:499) ~[na:1.8.0_241]
    at org.springframework.data.repository.core.support.RepositoryFactorySupport$QueryExecutorMethodInterceptor.mapMethodsToQuery(RepositoryFactorySupport.java:569) ~[spring-data-commons-2.2.4.RELEASE.jar:2.2.4.RELEASE]
    at org.springframework.data.repository.core.support.RepositoryFactorySupport$QueryExecutorMethodInterceptor.lambda$new$0(RepositoryFactorySupport.java:559) ~[spring-data-commons-2.2.4.RELEASE.jar:2.2.4.RELEASE]
    at java.util.Optional.map(Optional.java:215) ~[na:1.8.0_241]
    at org.springframework.data.repository.core.support.RepositoryFactorySupport$QueryExecutorMethodInterceptor.<init>(RepositoryFactorySupport.java:559) ~[spring-data-commons-2.2.4.RELEASE.jar:2.2.4.RELEASE]
    at org.springframework.data.repository.core.support.RepositoryFactorySupport.getRepository(RepositoryFactorySupport.java:332) ~[spring-data-commons-2.2.4.RELEASE.jar:2.2.4.RELEASE]
    at org.springframework.data.repository.core.support.RepositoryfactorybeanSupport.lambda$afterPropertiesSet$5(RepositoryfactorybeanSupport.java:297) ~[spring-data-commons-2.2.4.RELEASE.jar:2.2.4.RELEASE]
    at org.springframework.data.util.Lazy.getNullable(Lazy.java:212) ~[spring-data-commons-2.2.4.RELEASE.jar:2.2.4.RELEASE]
    at org.springframework.data.util.Lazy.get(Lazy.java:94) ~[spring-data-commons-2.2.4.RELEASE.jar:2.2.4.RELEASE]
    at org.springframework.data.repository.core.support.RepositoryfactorybeanSupport.afterPropertiesSet(RepositoryfactorybeanSupport.java:300) ~[spring-data-commons-2.2.4.RELEASE.jar:2.2.4.RELEASE]
    at org.springframework.data.jpa.repository.support.JpaRepositoryfactorybean.afterPropertiesSet(JpaRepositoryfactorybean.java:121) ~[spring-data-jpa-2.2.4.RELEASE.jar:2.2.4.RELEASE]
    at org.springframework.beans.factory.support.AbstractAutowireCapablebeanfactory.invokeInitMethods(AbstractAutowireCapablebeanfactory.java:1855) ~[spring-beans-5.2.3.RELEASE.jar:5.2.3.RELEASE]
    at org.springframework.beans.factory.support.AbstractAutowireCapablebeanfactory.initializeBean(AbstractAutowireCapablebeanfactory.java:1792) ~[spring-beans-5.2.3.RELEASE.jar:5.2.3.RELEASE]
    ... 42 common frames omitted
Caused by: java.lang.IllegalArgumentException: org.hibernate.hql.internal.ast.QuerySyntaxException: Invalid path: 'e.id' [SELECT new com.techavidus.networkingPhoniex.responseDTO.ManageGroupsDTO(g.group_id,g.group_name,gs.name) FROM com.techavidus.networkingPhoniex.model.Groups g LEFT JOIN com.techavidus.networkingPhoniex.model.MemberFollowGroups mgf LEFT JOIN mgf.groups gf ON gf.group_id = g.group_id JOIN g.groupTypes gt LEFT JOIN g.primary_contact_member_id pm LEFT JOIN g.secondary_contact_member_id sm LEFT JOIN g.groupStates gs WHERE (pm.member_id=:memberId OR sm.member_id=:memberId) IN (SELECT e FROM com.techavidus.networkingPhoniex.model.Events e LEFT JOIN e.eventRecurrence er LEFT JOIN e.groups eg ON eg.group_id = g.group_id WHERE e.startDate >=:todayDate) AND (SELECT ee FROM com.techavidus.networkingPhoniex.model.Events ee LEFT JOIN ee.eventRecurrence er LEFT JOIN ee.groups eg ON eg.group_id = g.group_id WHERE ee.startDate <:todayDate) GROUP BY g.group_id]
    at org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:138) ~[hibernate-core-5.4.10.Final.jar:5.4.10.Final]
    at org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:181) ~[hibernate-core-5.4.10.Final.jar:5.4.10.Final]
    at org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:188) ~[hibernate-core-5.4.10.Final.jar:5.4.10.Final]
    at org.hibernate.internal.AbstractSharedSessionContract.createquery(AbstractSharedSessionContract.java:718) ~[hibernate-core-5.4.10.Final.jar:5.4.10.Final]
    at org.hibernate.internal.AbstractSessionImpl.createquery(AbstractSessionImpl.java:23) ~[hibernate-core-5.4.10.Final.jar:5.4.10.Final]
    at sun.reflect.GeneratedMethodAccessor55.invoke(UnkNown Source) ~[na:na]
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.8.0_241]
    at java.lang.reflect.Method.invoke(Method.java:498) ~[na:1.8.0_241]
    at org.springframework.orm.jpa.ExtendedEntityManagerCreator$ExtendedEntityManagerInvocationHandler.invoke(ExtendedEntityManagerCreator.java:368) ~[spring-orm-5.2.3.RELEASE.jar:5.2.3.RELEASE]
    at com.sun.proxy.$Proxy110.createquery(UnkNown Source) ~[na:na]
    at org.springframework.data.jpa.repository.query.SimpleJpaQuery.validateQuery(SimpleJpaQuery.java:87) ~[spring-data-jpa-2.2.4.RELEASE.jar:2.2.4.RELEASE]
    ... 71 common frames omitted
Caused by: org.hibernate.hql.internal.ast.QuerySyntaxException: Invalid path: 'e.id' [SELECT new com.techavidus.networkingPhoniex.responseDTO.ManageGroupsDTO(g.group_id,gs.name) FROM com.techavidus.networkingPhoniex.model.Groups g LEFT JOIN com.techavidus.networkingPhoniex.model.MemberFollowGroups mgf LEFT JOIN mgf.groups gf ON gf.group_id = g.group_id JOIN g.groupTypes gt LEFT JOIN g.primary_contact_member_id pm LEFT JOIN g.secondary_contact_member_id sm LEFT JOIN g.groupStates gs WHERE (pm.member_id=:memberId OR sm.member_id=:memberId) IN (SELECT e FROM com.techavidus.networkingPhoniex.model.Events e LEFT JOIN e.eventRecurrence er LEFT JOIN e.groups eg ON eg.group_id = g.group_id WHERE e.startDate >=:todayDate) AND (SELECT ee FROM com.techavidus.networkingPhoniex.model.Events ee LEFT JOIN ee.eventRecurrence er LEFT JOIN ee.groups eg ON eg.group_id = g.group_id WHERE ee.startDate <:todayDate) GROUP BY g.group_id]
    at org.hibernate.hql.internal.ast.QuerySyntaxException.convert(QuerySyntaxException.java:74) ~[hibernate-core-5.4.10.Final.jar:5.4.10.Final]
    at org.hibernate.hql.internal.ast.ErrorTracker.throwQueryException(ErrorTracker.java:93) ~[hibernate-core-5.4.10.Final.jar:5.4.10.Final]
    at org.hibernate.hql.internal.ast.QueryTranslatorImpl.analyze(QueryTranslatorImpl.java:278) ~[hibernate-core-5.4.10.Final.jar:5.4.10.Final]
    at org.hibernate.hql.internal.ast.QueryTranslatorImpl.doCompile(QueryTranslatorImpl.java:192) ~[hibernate-core-5.4.10.Final.jar:5.4.10.Final]
    at org.hibernate.hql.internal.ast.QueryTranslatorImpl.compile(QueryTranslatorImpl.java:144) ~[hibernate-core-5.4.10.Final.jar:5.4.10.Final]
    at org.hibernate.engine.query.spi.HQLQueryPlan.<init>(HQLQueryPlan.java:113) ~[hibernate-core-5.4.10.Final.jar:5.4.10.Final]
    at org.hibernate.engine.query.spi.HQLQueryPlan.<init>(HQLQueryPlan.java:73) ~[hibernate-core-5.4.10.Final.jar:5.4.10.Final]
    at org.hibernate.engine.query.spi.QueryPlanCache.getHQLQueryPlan(QueryPlanCache.java:155) ~[hibernate-core-5.4.10.Final.jar:5.4.10.Final]
    at org.hibernate.internal.AbstractSharedSessionContract.getQueryPlan(AbstractSharedSessionContract.java:600) ~[hibernate-core-5.4.10.Final.jar:5.4.10.Final]
    at org.hibernate.internal.AbstractSharedSessionContract.createquery(AbstractSharedSessionContract.java:709) ~[hibernate-core-5.4.10.Final.jar:5.4.10.Final]
    ... 78 common frames omitted

解决方法

似乎您对查询机制有误解。

  1. 无论如何都不应进行new调用-jpa可以为您组装实体,而select new ...在设计上对我来说似乎是错误的。
  2. JpaRepository<Groups,Long>如果要获得List<ManageGroupsDTO>的返回类型,则看起来是错误的-应该像JpaRepository<ManageGroupsDTO,Long>
  3. 您的实体的
  4. @ToString注释很可能是多余的,因为@Data注释还包括.toString()方法创建afaik。

总结一下,尝试这样的事情:

@Repository
public interface GroupsDao extends JpaRepository<ManageGroupsDTO,Long> {

   @Query("SELECT g.group_id,g.group_name,gt.group_type_id,gt.name,COUNT(e.id),COUNT(ee.id),COUNT(mgf.id),gs.name " +
            "FROM Groups g LEFT JOIN MemberFollowGroups mgf LEFT JOIN mgf.groups gf ON gf.group_id = g.group_id " +
            "JOIN g.groupTypes gt LEFT JOIN g.primary_contact_member_id pm " +
            "LEFT JOIN g.secondary_contact_member_id sm LEFT JOIN g.groupStates gs " +
            "WHERE (pm.member_id=:memberId OR sm.member_id=:memberId) IN " +
            "(SELECT e FROM Events e LEFT JOIN e.eventRecurrence er LEFT JOIN e.groups eg ON eg.group_id = g.group_id WHERE e.startDate >=:todayDate) AND " +
            "(SELECT ee FROM Events ee LEFT JOIN ee.eventRecurrence er LEFT JOIN ee.groups eg ON eg.group_id = g.group_id WHERE ee.startDate <:todayDate) " +
            "GROUP BY g.group_id")
    List<ManageGroupsDTO> manageMyGroupList(LocalDate todayDate,Long memberId);
}

如果您对结果集的定位不感到困惑,则应采用这种方式进行修复。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。