https://school.programmers.co.kr/learn/courses/30/lessons/293261
[문제]
물고기 종류 별로 가장 큰 물고기의 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;
'프로그래머스 > My SQL' 카테고리의 다른 글
대장균들의 자식의 수 구하기 (0) | 2024.12.11 |
---|---|
특정 조건을 만족하는 물고기별 수와 최대 길이 구하기 (0) | 2024.12.09 |
업그레이드 할 수 없는 아이템 구하기 (0) | 2024.12.07 |
조회수가 가장 많은 중고거래 게시판의 첨부파일 조회하기 (0) | 2024.12.06 |
부서별 평균 연봉 조회하기 (0) | 2024.12.04 |