본문 바로가기

카테고리 없음

[프로그래머스 SQL 고득점 Kit] SELECT LV1 - 평균 일일 대여 요금 구하기 - MySQL

1. 문제 링크

    • 프로그래머스 코딩테스트 연습 > SELECT > 평균 일일 대여 요금 구하기 문제입니다.
  1. 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. 파이팅!