[SQL] 입양 시각 구하기(1), (2)★

야금야금 공부·2023년 4월 3일

SQL

목록 보기
23/28

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

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


1. 입양 시각 구하기(1)

ANIMAL_OUTS테이블은 동물 보호소에서 입양 보낸 동물의 정보를 담은 테이블입니다. ANIMAL_OUTS테이블 구조는 다음과 같으며, ANIMAL_ID, ANIMAL_TYPE, DATETIME, NAME, SEX_UPON_OUTCOME는 각각 동물의 아이디, 생물 종, 입양일, 이름, 성별 및 중성화 여부를 나타냅니다.

NAMETYPENULLABLE
ANIMAL_IDVARCHAR(N)FALSE
ANIMAL_TYPEVARCHAR(N)FALSE
DATETIMEDATETIMEFALSE
NAMEVARCHAR(N)TRUE
SEX_UPON_OUTCOMEVARCHAR(N)FALSE

보호소에서는 몇 시에 입양이 가장 활발하게 일어나는지 알아보려 합니다. 09:00부터 19:59까지, 각 시간대별로 입양이 몇 건이나 발생했는지 조회하는 SQL문을 작성해주세요. 이때 결과는 시간대 순으로 정렬해야 합니다.

문제 풀이

  • HOUR을 활용해 시간 추출
  • HOUR별로 출력 : GROUP BY HOUR
SELECT HOUR(DATETIME) AS HOUR, COUNT(*) AS COUNT 
FROM ANIMAL_OUTS
GROUP BY HOUR
HAVING HOUR BETWEEN 9 AND 20
ORDER BY HOUR

2. 입양 시각 구하기(2)

보호소에서는 몇 시에 입양이 가장 활발하게 일어나는지 알아보려 합니다. 0시부터 23시까지, 각 시간대별로 입양이 몇 건이나 발생했는지 조회하는 SQL문을 작성해주세요. 이때 결과는 시간대 순으로 정렬해야 합니다.

  • 0시부터 23시까지 모든 시간을 조회해야함
SET @HOUR_LIST = -1;

SELECT (@HOUR_LIST := @HOUR_LIST + 1) AS HOUR, 
(SELECT COUNT(*) FROM ANIMAL_OUTS WHERE HOUR(DATETIME) = @HOUR_LIST) AS COUNT 
FROM ANIMAL_OUTS
WHERE @HOUR_LIST < 23
  • SET을 활용해 변수명과 초기값 설정
  • :=은 대입 연산
  • SELECT구문이 실행되면 +1되어 HOUR_LIST = 0부터 시작한다.
  • WHERE @HOUR_LIST < 23 일때까지, @HOUR_LIST 값이 계속 1 증가한다.

0개의 댓글