SQL/GROUP BY
[프로그래머스 SQL] Lv.4 - 연간 평가점수에 해당하는 평가 등급 및 성과금조회하기
이런개발
2025. 4. 14. 12:45
https://school.programmers.co.kr/learn/courses/30/lessons/284528
프로그래머스
SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
문제 풀이
- HR_EMPLOYEES 테이블과 HR_GRADE 테이블을 조인한다.
- 이때 HR_GRADE 테이블은 서브 쿼리로 평가 등급을 구해야 한다. 사번을 기준으로 그룹핑하고, 평가 점수의 평균에 따라 S, A, B, C 중 하나로 조회한다.
- 사번, 성명, 평가 등급, 성과금을 조회한다. 성과금은 서브 쿼리에서 조회한 등급에 맞게 알맞은 값으로 계산해 준다.
- 사번을 기준으로 오름차순 정렬한다.
SELECT
E.EMP_NO,
E.EMP_NAME,
G.GRADE,
CASE
WHEN G.GRADE = 'S' THEN E.SAL * 0.2
WHEN G.GRADE = 'A' THEN E.SAL * 0.15
WHEN G.GRADE = 'B' THEN E.SAL * 0.10
ELSE 0
END AS BONUS
FROM
HR_EMPLOYEES E JOIN (
SELECT EMP_NO, CASE
WHEN AVG(SCORE) >= 96 THEN 'S'
WHEN AVG(SCORE) >= 90 THEN 'A'
WHEN AVG(SCORE) >= 80 THEN 'B'
ELSE 'C'
END AS GRADE
FROM HR_GRADE
GROUP BY EMP_NO
) AS G ON E.EMP_NO = G.EMP_NO
ORDER BY 1