簡體   English   中英

如何在QueryDSL中按日期分組?

[英]How to group by date in QueryDSL?

我有跟隨JPA實體:

@Table(name = "execute")
public class ScenarioExecution {
    .
    .
    .
    @Column(name = "date")
    @Temporal(TemporalType.TIMESTAMP)
    private Date date;
    .
    .
    .
}

其中date作為TIMESTAMP存儲,因此它包含日期和時間。 我想要的是在SQL中查找所有日期,但四舍五入到整天:

SELECT CAST(e.DATE AS DATE) as day FROM EXECUTE e GROUP BY day

如何將其翻譯為QueryDSL? 我試過了:

JPAQuery query = new JPAQuery(entityManager);
QScenarioExecution executions = QScenarioExecution.scenarioExecution;
DateExpression<Date> alias = DateTemplate.create(Date.class, "CAST({0} as DATE)", executions.date).as("day");
    return query.from(executions)
            .groupBy(alias)
            .list(alias);

但是我有異常java.lang.IllegalStateException: scenarioExecution is already used 我使用H2作為數據庫后端。

編輯:完整的堆棧跟蹤:

java.lang.IllegalStateException: scenarioExecution is already used
    at com.mysema.query.DefaultQueryMetadata.addJoin(DefaultQueryMetadata.java:172)
    at com.mysema.query.support.QueryMixin.from(QueryMixin.java:162)
    at com.mysema.query.jpa.JPAQueryBase.from(JPAQueryBase.java:84)
    at {cut}.dao.ScenarionExecutionDAO.getExecutionDates(ScenarionExecutionDAO.java:105)
    at {cut}.dao.SearchingTest.findExecutionDates(SearchingTest.java:60)

編輯2:

我已經改變了一點方法。 現在它看起來像:

public List<Date> getExecutionDates() {
    EntityManager entityManager = createEntityManager();
    JPAQuery query = new JPAQuery(entityManager);
    QScenarioExecution executions = QScenarioExecution.scenarioExecution;
    try {
        DateExpression<Date> alias = DateTemplate.create(Date.class, "CAST({0} as DATE)", executions.date);
        return query.from(executions)
                .groupBy(alias)
                .list(alias);
    } finally {
        entityManager.close();
    }
}

但現在它拋出了這樣的異常:

java.lang.IllegalStateException: No data type for node: org.hibernate.hql.internal.ast.tree.MethodNode 
 \-[METHOD_CALL] MethodNode: '('
    +-[METHOD_NAME] IdentNode: 'CAST' {originalText=CAST}
    \-[EXPR_LIST] SqlNode: 'exprList'
       +-[DOT] DotNode: 'scenarioex0_.date' {propertyName=date,dereferenceType=PRIMITIVE,getPropertyPath=date,path=scenarioExecution.date,tableAlias=scenarioex0_,className={cut}.db.monitorLocal.model.ScenarioExecution,classAlias=scenarioExecution}
       |  +-[ALIAS_REF] IdentNode: 'scenarioex0_.id' {alias=scenarioExecution, className={cut}.db.monitorLocal.model.ScenarioExecution, tableAlias=scenarioex0_}
       |  \-[IDENT] IdentNode: 'date' {originalText=date}
       \-[IDENT] IdentNode: 'DATE' {originalText=DATE}
    at org.hibernate.hql.internal.ast.tree.SelectClause.initializeExplicitSelectClause(SelectClause.java:174)
    at org.hibernate.hql.internal.ast.HqlSqlWalker.useSelectClause(HqlSqlWalker.java:923)
    at org.hibernate.hql.internal.ast.HqlSqlWalker.processQuery(HqlSqlWalker.java:691)
    at org.hibernate.hql.internal.antlr.HqlSqlBaseWalker.query(HqlSqlBaseWalker.java:663)
    at org.hibernate.hql.internal.antlr.HqlSqlBaseWalker.selectStatement(HqlSqlBaseWalker.java:299)
    at org.hibernate.hql.internal.antlr.HqlSqlBaseWalker.statement(HqlSqlBaseWalker.java:247)
    at org.hibernate.hql.internal.ast.QueryTranslatorImpl.analyze(QueryTranslatorImpl.java:278)
    at org.hibernate.hql.internal.ast.QueryTranslatorImpl.doCompile(QueryTranslatorImpl.java:206)
    at org.hibernate.hql.internal.ast.QueryTranslatorImpl.compile(QueryTranslatorImpl.java:158)
    at org.hibernate.engine.query.spi.HQLQueryPlan.<init>(HQLQueryPlan.java:126)
    at org.hibernate.engine.query.spi.HQLQueryPlan.<init>(HQLQueryPlan.java:88)
    at org.hibernate.engine.query.spi.QueryPlanCache.getHQLQueryPlan(QueryPlanCache.java:190)
    at org.hibernate.internal.AbstractSessionImpl.getHQLQueryPlan(AbstractSessionImpl.java:301)
    at org.hibernate.internal.AbstractSessionImpl.createQuery(AbstractSessionImpl.java:236)
    at org.hibernate.internal.SessionImpl.createQuery(SessionImpl.java:1800)
    at org.hibernate.jpa.spi.AbstractEntityManagerImpl.createQuery(AbstractEntityManagerImpl.java:328)
    at com.mysema.query.jpa.impl.AbstractJPAQuery.createQuery(AbstractJPAQuery.java:128)
    at com.mysema.query.jpa.impl.AbstractJPAQuery.createQuery(AbstractJPAQuery.java:97)
    at com.mysema.query.jpa.impl.AbstractJPAQuery.list(AbstractJPAQuery.java:241)
    at {cut}.monitorLocal.dao.ScenarionExecutionDAO.getExecutionDates(ScenarionExecutionDAO.java:109)
    at {cut}.storage.db.monitorLocal.dao.SearchingTest.findExecutionDates(SearchingTest.java:61)

你確定你不是兩次打電話嗎? 另外一天路徑需要是groupBy的參數,而不是完整的別名表達式。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM