How to group by date in QueryDSL?

I have the following JPA entity:

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

      

where date

is stored as TIMESTAMP

, so it includes date and time. I want to find all dates, but rounded to a whole day, in SQL:

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

      

How can I translate it to QueryDSL? I tried:

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);

      

but I have an exception java.lang.IllegalStateException: scenarioExecution is already used

. I am using H2 as my database.

EDIT: Full stack:

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)

      

EDIT 2:

I changed the method a bit. It now looks like this:

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();
    }
}

      

But now it throws an exception like this:

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)

      

+3


source to share


1 answer


Are you sure you don't call twice? Also the day path must be an argument to groupBy, not a full alias expression.



+1


source







All Articles