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

자두·2022년 9월 30일
post-thumbnail

문제 살펴보기
ANIMAL_OUTS
테이블은 동물 보호소에서 입양 보낸 동물의 정보를 담은 테이블입니다. ANIMAL_OUTS 테이블 구조는 다음과 같으며, ANIMAL_IDANIMAL_TYPEDATETIMENAMESEX_UPON_OUTCOME
는 각각 동물의 아이디, 생물 종, 입양일, 이름, 성별 및 중성화 여부를 나타냅니다.
보호소에서는 몇 시에 입양이 가장 활발하게 일어나는지 알아보려 합니다. 0시부터 23시까지, 각 시간대별로 입양이 몇 건이나 발생했는지 조회하는 SQL문을 작성해주세요. 이때 결과는 시간대 순으로 정렬해야 합니다.

요약하자면
1. 0시부터 23시까지 각 시간대별로
2. 입양이 몇 건이나 발생했는지 조회
3. 결과는 시간대 순으로 정렬

💡 SET
변수에 특정값을 할당할 때 사용하는 명령어

SET @HOUR = -1;
SELECT (@HOUR:= @HOUR+1) HOUR
FROM ANIMAL_OUTS
WHERE @HOUR <= 22;

이 쿼리의 뜻은
@HOUR 이라는 변수에 -1 을 할당한 후
22까지 1씩 더해준다(23까지 나와야하니까)는 뜻

WRONG ANSWER

SET @HOUR = -1;
SELECT (@HOUR:= @HOUR+1) HOUR,
(SELECT COUNT(HOUR(datetime))
FROM ANIMAL_OUTS)
FROM ANIMAL_OUTS
WHERE @HOUR <= 22;

카운트가 안 된 듯한 느낌
COUNT 식에 변수설정 해줌

(SELECT COUNT(HOUR(datetime)) FROM ANIMAL_OUTS WHERE HOUR(datetime) = @HOUR) COUNT

RIGHT ANSWER

SET @HOUR = -1;
SELECT (@HOUR:= @HOUR+1) HOUR,
(SELECT COUNT(HOUR(datetime))
	FROM ANIMAL_OUTS
	WHERE HOUR(datetime) = @HOUR) COUNT
FROM ANIMAL_OUTS
WHERE @HOUR <= 22;

profile
하고 싶은 일과 해야 하는 일을 병행하는 데이터 분석기

0개의 댓글