1. 문제 링크
-
- 프로그래머스 코딩테스트 연습 > SELECT > 평균 일일 대여 요금 구하기 문제입니다.
- https://school.programmers.co.kr/learn/courses/30/lessons/151136
2. 문제
다음은 어느 자동차 대여 회사에서 대여중인 자동차들의 정보를 담은 CAR_RENTAL_COMPANY_CAR 테이블입니다. CAR_RENTAL_COMPANY_CAR 테이블은 아래와 같은 구조로 되어있으며, CAR_ID, CAR_TYPE, DAILY_FEE, OPTIONS 는 각각 자동차 ID, 자동차 종류, 일일 대여 요금(원), 자동차 옵션 리스트를 나타냅니다.

자동차 종류는 '세단', 'SUV', '승합차', '트럭', '리무진' 이 있습니다. 자동차 옵션 리스트는 콤마(',')로 구분된 키워드 리스트(예: '열선시트', '스마트키', '주차감지센서')로 되어있으며, 키워드 종류는 '주차감지센서', '스마트키', '네비게이션', '통풍시트', '열선시트', '후방카메라', '가죽시트' 가 있습니다.
CAR_RENTAL_COMPANY_CAR 테이블에서 자동차 종류가 'SUV'인 자동차들의 평균 일일 대여 요금을 출력하는 SQL문을 작성해주세요. 이때 평균 일일 대여 요금은 소수 첫 번째 자리에서 반올림하고, 컬럼명은 AVERAGE_FEE 로 지정해주세요.
3. 예시
예를 들어 CAR_RENTAL_COMPANY_CAR 테이블이 다음과 같다면

'SUV' 에 해당하는 자동차들의 평균 일일 대여 요금은 18,000 원 이므로, 다음과 같은 결과가 나와야 합니다.

4. 문제 풀이 포인트 - 소수점 반올림 함수, 평균 구하기 함수
평균 일일 대여 요금은,
소수 첫 번째 자리에서 반올림
숫자를 반올림하는 방법에는 MySQL에서 3가지가 있습니다.
4-1. ROUND(): 숫자를 반올림하는 함수
ROUND(number, decimal_places) 의 형식을 가지고 있습니다.
number: 반올림할 숫자입니다.
decimal_places: 반올림하고자 하는 자릿수 위치를 나타냅니다. 이 값은 선택적이며, 지정하지 않으면 숫자가 정수로 반올림됩니다.
0을 포함한 양수는 소수점을, 음수는 정수 위치를 나타냅니다.
정수 첫번째 자리에서 반올림
SELECT ROUND(1234.56789, -1)

소수점 첫번째 자리에서 반올림
SELECT ROUND(1234.56789, 0)
소수점 두번째 자리에서 반올림
SELECT ROUND(1234.56789, 1)
4-2. CEIL(): 숫자를 올림하는 함수
CEIL(number)
CEIL() 함수는 주어진 숫자를 올림한 결과를 반환합니다. 즉, 해당 숫자보다 크거나 같은 최소 정수를 반환합니다.
예를 들어
SELECT CEIL(5.3); -- 6
SELECT CEIL(7.8); -- 8
SELECT CEIL(-2.4); -- -2
4-3. FLOOR(): 숫자를 내림합니다.
FLOOR(number)
FLOOR() 함수는 주어진 숫자를 내림한 결과를 반환합니다. 즉, 해당 숫자보다 작거나 같은 최대 정수를 반환합니다.
예를 들어
SELECT FLOOR(5.3); -- 5
SELECT FLOOR(7.8); -- 7
SELECT FLOOR(-2.4); -- -3
5. 문제 풀이
-- 평균 일일 대여 요금
SELECT AVG(DAILY_FEE)
-- 소수 첫 번째 자리에서 반올림
SELECT ROUND(AVG(DAILY_FEE), 0)
-- 컬럼명은 AVERAGE_FEE 로 지정해주세요.
SELECT ROUND(AVG(DAILY_FEE), 0) AS AVERAGE_FEE
6. 완성 코드
SELECT
ROUND(AVG(DAILY_FEE), 0) AS AVERAGE_FEE
FROM
CAR_RENTAL_COMPANY_CAR
WHERE
CAR_TYPE = 'SUV'
PS. 파이팅!