프로그래머스/My SQL

물고기 종류 별 대어 찾기

싱싱한복초이 2024. 12. 8. 10:48

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

 

프로그래머스

SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프

programmers.co.kr

[문제]

물고기 종류 별로 가장 큰 물고기의 ID, 물고기 이름, 길이를 출력하는 SQL 문을 작성해주세요.

물고기의 ID 컬럼명은 ID, 이름 컬럼명은 FISH_NAME, 길이 컬럼명은 LENGTH로 해주세요.
결과는 물고기의 ID에 대해 오름차순 정렬해주세요.
단, 물고기 종류별 가장 큰 물고기는 1마리만 있으며 10cm 이하의 물고기가 가장 큰 경우는 없습니다.

 

[나의 풀이]

WITH A AS(
    SELECT I.FISH_TYPE, FISH_NAME, MAX(LENGTH) LENGTH
    FROM FISH_INFO I LEFT JOIN FISH_NAME_INFO N
    ON I.FISH_TYPE = N.FISH_TYPE
    GROUP BY FISH_TYPE, FISH_NAME)
    
SELECT ID, A.FISH_NAME, A.LENGTH
FROM A LEFT JOIN FISH_INFO I
ON A.LENGTH = I.LENGTH AND A.FISH_TYPE = I.FISH_TYPE
ORDER BY ID;

 

[다른 풀이]

SELECT I.ID, N.FISH_NAME, I.LENGTH
FROM FISH_INFO I
JOIN FISH_NAME_INFO N
ON I.FISH_TYPE = N.FISH_TYPE
AND I.LENGTH = (
    SELECT MAX(LENGTH)
    FROM FISH_INFO
    WHERE FISH_TYPE = I.FISH_TYPE
)
ORDER BY I.ID;

Q.서브쿼리절 안에 들어가는 WHERE절은 무슨 의미이며, WHERE절 대신 GROUP BY가 들어가면 안되는지?

 

 

+) GROUP BY를 사용한 경우

SELECT ID, FISH_NAME, LENGTH 
FROM FISH_INFO I
INNER JOIN FISH_NAME_INFO N
ON I.FISH_TYPE = N.FISH_TYPE
WHERE (I.FISH_TYPE, LENGTH) IN (SELECT FISH_TYPE, MAX(LENGTH)
                                FROM FISH_INFO
                                GROUP BY FISH_TYPE)
ORDER BY 1;