[프로그래머스] SQL 고득점 kit(연도 별 평균 미세먼지 농도 조회하기)

728x90

문제 설명


AIR_POLLUTION 테이블은 전국의 월별 미세먼지 정보를 담은 테이블입니다. AIR_POLLUTION 테이블의 구조는 다음과 같으며 LOCATION1, LOCATION2, YM, PM_VAL1, PM_VAL2은 각각 지역구분1, 지역구분2, 측정일, 미세먼지 오염도, 초미세먼지 오염도를 의미합니다.

 

문제

 

AIR_POLLUTION 테이블에서 수원 지역의 연도 별 평균 미세먼지 오염도와 평균 초미세먼지 오염도를 조회하는 SQL문을 작성해주세요. 이때, 평균 미세먼지 오염도와 평균 초미세먼지 오염도의 컬럼명은 각각 PM10, PM2.5로 해 주시고, 값은 소수 셋째 자리에서 반올림해주세요. 결과는 연도를 기준으로 오름차순 정렬해주세요.

 

내 코드

SELECT YEAR(YM) AS YEAR, ROUND(AVG(PM_VAL1), 3) AS PM10, ROUND(AVG(PM_VAL2),3) AS 'PM2.5'
FROM AIR_POLLUTION
WHERE LOCATION2 = '수원'
GROUP BY YEAR
ORDER BY YEAR

 

1. ROUND(숫자 or 열 이름, 반올림 기준)

  • 반올림 기준: 소수점 자리 값 지정
  • 지정하지 않으면 소수점 첫번째 자리를 사용(주의!)

2. WHERE, HAVING 차이

  • WHERE: 그룹화 전에 데이터를 필터링하는 데 사용
  • HAVING: 그룹화 후에 조건을 걸 때 사용됩니다.

3. YEAR, DATE_FORMAT 차이

  • YEAR: 정수로 반환
  • DATE_FORMAT: 문자열로 반환
728x90