
문제 살펴보기
ANIMAL_OUTS
테이블은 동물 보호소에서 입양 보낸 동물의 정보를 담은 테이블입니다.ANIMAL_OUTS테이블 구조는 다음과 같으며,ANIMAL_ID,ANIMAL_TYPE,DATETIME,NAME,SEX_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;
