[Database] 입양 시각 구하기(2)

[프로그래머스] 입양 시각 구하기(2) MySQL

문제 : 프로그래머스_입양 시각 구하기(2)

문제 설명

문제에서 동물 보호소에서 입양 보낸 동물의 정보가 담긴 테이블이 주어집니다.
테이블의 DATETIME 칼럼에는 동물을 입양 보낸 시간이 주어지는데, 이때 각 시간별로(0시 ~ 23시) 입양이 몇 건 발생했는지를 조회하는 SQL 문을 작성해야 합니다.


Solution

사용자 변수 선언, Subquery

@hour라는 사용자 변수를 선언하고 -1로 초기화해 줍니다.(sql의 사용자 변수는 @~로 시작합니다.)
@hour을 1씩 증가시켜주면서 각 시간별 count를 조회하는 서브쿼리문으로 시간별 입양 수를 조회합니다.
DATETIME에서 HOUR 정보만 추출해야 하므로, HOUR() 함수를 이용합니다.
이때 hour+1까지 조회되므로, WHERE 절의 조건은 23보다 작아야 합니다.


풀이

SET @hour = -1;
SELECT (@hour := @hour+1) as HOUR,
(SELECT COUNT(DATETIME) FROM ANIMAL_OUTS WHERE HOUR(DATETIME) = @hour)
as COUNT
FROM ANIMAL_OUTS
WHERE @hour < 23;