본문 바로가기
TIL - 프로그래밍/SQL

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

by chaemj97 2023. 7. 11.
728x90

https://school.programmers.co.kr/learn/courses/30/lessons/59413

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr


  • 문제

 

  • 풀이

각 시간별 개수 세기

문제 : 존재하지 않는 시간이 나타나지 않는다.

SELECT HOUR(DATETIME), COUNT(*)
FROM ANIMAL_OUTS
GROUP BY HOUR(DATETIME)
ORDER BY HOUR(DATETIME);

0~6, 20~23 존재하지 않는 시간의 COUNT는 0으로 나와야하니 시간 컬럼을 만들어야겠다

-> 가상 테이블 만들기

https://chaemi720.tistory.com/331

 

[SQL] WITH 절 / WITH RECURSIVE 절

WITH 절 임시테이블 or 가상 테이블 반복되는 서브쿼리 블록을 하나의 WITH 절 블록으로 만들어서 사용 가능 한 번 실행할 쿼리문 내 정의하여 해당 쿼리 안에서만 실행 # 가상 테이블 만들기 WITH 이

chaemi720.tistory.com

 

  • 코드
-- 시간 0~23 테이블 만들기
WITH RECURSIVE TIME_HOUR AS (
    SELECT 0 AS H
    UNION
    SELECT H+1 FROM TIME_HOUR WHERE H < 23
)

SELECT T.H, COUNT(ANIMAL_ID)
FROM TIME_HOUR AS T
    LEFT JOIN ANIMAL_OUTS AS O
        ON T.H = HOUR(O.DATETIME)
GROUP BY T.H;
728x90
반응형

댓글