/******************************************************************************* * Copyright (c) 2014 antoniomariasanchez at gmail.com. * All rights reserved. This program and the accompanying materials * are made available under the terms of the GNU Public License v3.0 * which accompanies this distribution, and is available at * http://www.gnu.org/licenses/gpl.html * * Contributors: * antoniomaria - initial API and implementation ******************************************************************************/ package net.sf.gazpachoquest.repository; import java.util.List; import net.sf.gazpachoquest.domain.core.Question; import net.sf.gazpachoquest.domain.core.QuestionnaireDefinition; import net.sf.gazpachoquest.repository.support.GenericRepository; import org.springframework.data.jpa.repository.Query; import org.springframework.data.repository.query.Param; public interface QuestionnaireDefinitionRepository extends GenericRepository<QuestionnaireDefinition> { /** * Returns questions count group by question group for a given * questionnaireDefinitionId * * <pre> * [11, 2, 0] = [sectionId, questionCount, order_in_questionnair] * [10, 3, 1] * [9, 2, 2] * </pre> * * @param questionnaireDefinitionId Integer * @return List */ @Query("select qg.id,count(q.id),index(qg) from QuestionnaireDefinition qd left join qd.sections qg left join qg.questions q where qd.id = :questionnaireDefinitionId group by qg.id order by index(qg)") List<Object[]> questionsCountGroupBySections(@Param("questionnaireDefinitionId") Integer questionnaireDefinitionId); @Query("select count(q) from QuestionnaireDefinition qd left join qd.sections qg left join qg.questions q where qd.id = :questionnaireDefinitionId") Integer questionsCount(@Param("questionnaireDefinitionId") Integer questionnaireDefinitionId); @Query("select q from QuestionnaireDefinition qd left join qd.sections qg left join qg.questions q where qd.id = :questionnaireDefinitionId") List<Question> getQuestions(@Param("questionnaireDefinitionId") Integer questionnaireDefinitionId); }