backend/buisnesslogic/src/main/java/com/plannaplan/repositories/GroupRepository.java

48 lines
1.8 KiB
Java
Raw Normal View History

package com.plannaplan.repositories;
2020-08-08 14:14:42 +02:00
import java.util.List;
import java.util.Optional;
2020-08-08 14:14:42 +02:00
import com.plannaplan.entities.Groups;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;
import org.springframework.stereotype.Repository;
/**
* GroupRepository.find:
* Return list of:
* SELECT * FROM Groups WHERE time = i AND room = j AND capacity = k .
*
* Where i, j, k, ?1, ?2, ?3 are equale to variables.
*
* GroupRepository.getByCourse:
* Return list of:
* SELECT * FROM Groups WHERE course_id = i .
*
* Where i, ?1 are equale to variables.
*/
@Repository
public interface GroupRepository extends JpaRepository<Groups, Long> {
2020-09-02 16:56:49 +02:00
@Query("FROM Groups WHERE time = ?1 AND room = ?2 AND capacity = ?3")
Optional<Groups> find(@Param("time") int time, @Param("room") String room, @Param("capacity") int capacity);
2020-08-08 14:14:42 +02:00
2020-09-02 16:56:49 +02:00
@Query("FROM Groups WHERE course_id = ?1")
2020-08-08 14:14:42 +02:00
List<Groups> getByCourse(@Param("id") Long id);
2020-11-17 19:36:56 +01:00
@Query("SELECT COUNT(*) AS assinged_times FROM Assignment WHERE isPastAssignment=false GROUP BY group HAVING group_id=?1")
2020-11-20 15:56:43 +01:00
Optional<Number> getAssignedAmount(Long groupId);
2020-11-17 19:36:56 +01:00
2020-11-27 16:55:15 +01:00
/**
* PLAIN SQL QUERY: SELECT group_id, COUNT(*) assinged_times FROM assignment
* WHERE is_past_assignment=0 GROUP BY group_id HAVING group_id IN (:ids)")
*
* @param groupIds list of groups ids
* @return list of objects arrays where first object is Groups instance and
* second is Long that is taken places value
*/
2020-11-26 13:58:27 +01:00
@Query("SELECT group, COUNT(*) AS assinged_times FROM Assignment a WHERE a.isPastAssignment=false GROUP BY a.group HAVING group_id IN (:ids)")
List<Object[]> getAssignedAmounts(@Param("ids") List<Long> groupIds);
}