GROUP BY 부서별 평균 연봉 조회하기

문건희·2025년 6월 8일

SQL_프로그래머스

목록 보기
2/3

좋은 지적 감사합니다! 아래는 문제 설명 + 예시 데이터 + 기대 출력 결과까지 모두 포함한 원문 전체 내용입니다:


문제 설명

HR_DEPARTMENT 테이블은 회사의 부서 정보를 담은 테이블입니다.
HR_DEPARTMENT 테이블의 구조는 다음과 같으며 DEPT_ID, DEPT_NAME_KR, DEPT_NAME_EN, LOCATION은 각각 부서 ID, 국문 부서명, 영문 부서명, 부서 위치를 의미합니다.

Column nameTypeNullable
DEPT_IDVARCHARFALSE
DEPT_NAME_KRVARCHARFALSE
DEPT_NAME_ENVARCHARFALSE
LOCATIONVARCHARFALSE

HR_EMPLOYEES 테이블은 회사의 사원 정보를 담은 테이블입니다.
HR_EMPLOYEES 테이블의 구조는 다음과 같으며 EMP_NO, EMP_NAME, DEPT_ID, POSITION, EMAIL, COMP_TEL, HIRE_DATE, SAL은 각각 사번, 성명, 부서 ID, 직책, 이메일, 전화번호, 입사일, 연봉을 의미합니다.

Column nameTypeNullable
EMP_NOVARCHARFALSE
EMP_NAMEVARCHARFALSE
DEPT_IDVARCHARFALSE
POSITIONVARCHARFALSE
EMAILVARCHARFALSE
COMP_TELVARCHARFALSE
HIRE_DATEDATEFALSE
SALNUMBERFALSE

문제

HR_DEPARTMENT와 HR_EMPLOYEES 테이블을 이용해 부서별 평균 연봉을 조회하려 합니다.
부서별로 부서 ID, 영문 부서명, 평균 연봉을 조회하는 SQL문을 작성해주세요.

  • 평균연봉은 소수점 첫째 자리에서 반올림하고 컬럼명은 AVG_SAL로 해주세요.
  • 결과는 부서별 평균 연봉을 기준으로 내림차순 정렬해주세요.

예시

HR_DEPARTMENT 테이블

DEPT_IDDEPT_NAME_KRDEPT_NAME_ENLOCATION
D0005재무팀Finance그렙타워 5층
D0006구매팀Purchasing그렙타워 5층
D0007마케팅팀Marketing그렙타워 6층

HR_EMPLOYEES 테이블

EMP_NOEMP_NAMEDEPT_IDPOSITIONEMAILCOMP_TELHIRE_DATESAL
2019003한동희D0005팀장donghee_han@grep.com031-8000-11222019-03-0157000000
2020032한명지D0005팀원mungji_han@grep.com031-8000-11232020-03-0152000000
2022003김보라D0005팀원bora_kim@grep.com031-8000-11262022-03-0147000000
2018005이재정D0006팀장jaejung_lee@grep.com031-8000-11272018-03-0160000000
2019032윤성희D0006팀원sunghee_yoon@grep.com031-8000-11282019-03-0157000000
2020009송영섭D0006팀원yungseop_song@grep.com031-8000-11302020-03-0151000000
2021006이성주D0006팀원sungju_lee@grep.com031-8000-11312021-03-0149000000
2018004이주리D0007팀장joori_lee@grep.com031-8000-11322018-03-0161000000
2020012김사랑D0007팀원sarang_kim@grep.com031-8000-11332020-03-0154000000
2021018김히라D0007팀원heera_kim@grep.com031-8000-11362021-03-0149000000

출력 예시

DEPT_IDDEPT_NAME_ENAVG_SAL
D0007Marketing54666667
D0006Purchasing54250000
D0005Finance52000000

SELECT 
    d.DEPT_ID AS DEPT_ID, 
    d.DEPT_NAME_EN AS DEPT_NAME_EN, 
    ROUND(AVG(SAL), 0) AS AVG_SAL
FROM hr_department d
    JOIN hr_employees e ON d.DEPT_ID = e.DEPT_ID
GROUP BY d.DEPT_ID, d.DEPT_NAME_EN
ORDER BY AVG(SAL) DESC;
SELECT 
    e.DEPT_ID AS DEPT_ID, 
    d.DEPT_NAME_EN AS DEPT_NAME_EN, 
    e.AVG_SAL AS AVG_SAL
FROM hr_department d JOIN (
        SELECT 
            dept_id, 
            ROUND(AVG(SAL), 0) AS AVG_SAL
        FROM hr_employees
        GROUP BY dept_id
        ) e ON d.dept_id = e.dept_id
ORDER BY e.avg_sal DESC;

0개의 댓글