74. 특정 기간동안 대여 가능한 자동차들의 대여비용 구하기

박은서's avatar
Mar 12, 2026
74. 특정 기간동안 대여 가능한 자동차들의 대여비용 구하기
2026.03.11(THU)_74일차

1. 문제

문제 설명

다음은 어느 자동차 대여 회사에서 대여 중인 자동차들의 정보를 담은 CAR_RENTAL_COMPANY_CAR 테이블과 자동차 대여 기록 정보를 담은 CAR_RENTAL_COMPANY_RENTAL_HISTORY 테이블과 자동차 종류 별 대여 기간 종류 별 할인 정책 정보를 담은 CAR_RENTAL_COMPANY_DISCOUNT_PLAN 테이블 입니다.
CAR_RENTAL_COMPANY_CAR 테이블은 아래와 같은 구조로 되어있으며, CAR_IDCAR_TYPEDAILY_FEEOPTIONS 는 각각 자동차 ID, 자동차 종류, 일일 대여 요금(원), 자동차 옵션 리스트를 나타냅니다.
Column name
Type
Nullable
CAR_ID
INTEGER
FALSE
CAR_TYPE
VARCHAR(255)
FALSE
DAILY_FEE
INTEGER
FALSE
OPTIONS
VARCHAR(255)
FALSE
자동차 종류는 '세단', 'SUV', '승합차', '트럭', '리무진' 이 있습니다. 자동차 옵션 리스트는 콤마(',')로 구분된 키워드 리스트(예: ''열선시트,스마트키,주차감지센서'')로 되어있으며, 키워드 종류는 '주차감지센서', '스마트키', '네비게이션', '통풍시트', '열선시트', '후방카메라', '가죽시트' 가 있습니다.
CAR_RENTAL_COMPANY_RENTAL_HISTORY 테이블은 아래와 같은 구조로 되어있으며, HISTORY_IDCAR_IDSTART_DATEEND_DATE 는 각각 자동차 대여 기록 ID, 자동차 ID, 대여 시작일, 대여 종료일을 나타냅니다.
Column name
Type
Nullable
HISTORY_ID
INTEGER
FALSE
CAR_ID
INTEGER
FALSE
START_DATE
DATE
FALSE
END_DATE
DATE
FALSE
CAR_RENTAL_COMPANY_DISCOUNT_PLAN 테이블은 아래와 같은 구조로 되어있으며, PLAN_IDCAR_TYPEDURATION_TYPEDISCOUNT_RATE 는 각각 요금 할인 정책 ID, 자동차 종류, 대여 기간 종류, 할인율(%)을 나타냅니다.
Column name
Type
Nullable
PLAN_ID
INTEGER
FALSE
CAR_TYPE
VARCHAR(255)
FALSE
DURATION_TYPE
VARCHAR(255)
FALSE
DISCOUNT_RATE
INTEGER
FALSE
할인율이 적용되는 대여 기간 종류로는 '7일 이상' (대여 기간이 7일 이상 30일 미만인 경우), '30일 이상' (대여 기간이 30일 이상 90일 미만인 경우), '90일 이상' (대여 기간이 90일 이상인 경우) 이 있습니다. 대여 기간이 7일 미만인 경우 할인정책이 없습니다.

문제

CAR_RENTAL_COMPANY_CAR 테이블과 CAR_RENTAL_COMPANY_RENTAL_HISTORY 테이블과 CAR_RENTAL_COMPANY_DISCOUNT_PLAN 테이블에서 자동차 종류가 '세단' 또는 'SUV' 인 자동차 중 2022년 11월 1일부터 2022년 11월 30일까지 대여 가능하고 30일간의 대여 금액이 50만원 이상 200만원 미만인 자동차에 대해서 자동차 ID, 자동차 종류, 대여 금액(컬럼명: FEE) 리스트를 출력하는 SQL문을 작성해주세요. 결과는 대여 금액을 기준으로 내림차순 정렬하고, 대여 금액이 같은 경우 자동차 종류를 기준으로 오름차순 정렬, 자동차 종류까지 같은 경우 자동차 ID를 기준으로 내림차순 정렬해주세요.

예시

예를 들어 CAR_RENTAL_COMPANY_CAR 테이블과 CAR_RENTAL_COMPANY_RENTAL_HISTORY 테이블과 CAR_RENTAL_COMPANY_DISCOUNT_PLAN 테이블이 다음과 같다면
CAR_ID
CAR_TYPE
DAILY_FEE
OPTIONS
1
SUV
25000
가죽시트,열선시트,후방카메라
2
세단
14000
스마트키,네비게이션,열선시트
3
트럭
32000
주차감지센서,후방카메라,가죽시트
4
세단
12000
열선시트,후방카메라
5
세단
22000
스마트키,주차감지센서
HISTORY_ID
CAR_ID
START_DATE
END_DATE
1
1
2022-08-27
2022-09-02
2
1
2022-10-03
2022-10-04
3
2
2022-10-05
2022-10-20
4
2
2022-10-10
2022-11-12
5
3
2022-10-16
2022-10-17
PLAN_ID
CAR_TYPE
DURATION_TYPE
DISCOUNT_RATE
1
트럭
7일 이상
5%
2
트럭
30일 이상
7%
3
트럭
90일 이상
10%
4
세단
7일 이상
5%
5
세단
30일 이상
10%
6
세단
90일 이상
15%
7
SUV
7일 이상
3%
8
SUV
30일 이상
8%
9
SUV
90일 이상
12%
자동차 종류가 '세단' 또는 'SUV' 인 자동차 중 2022년 11월 1일 부터 2022년 11월 30일까지 대여가능한 자동차는 자동차 ID가 1, 4, 5인 자동차입니다.
일일 대여 요금에 자동차 종류 별 대여기간이 30일 이상인 경우의 할인율을 적용하여 30일간의 대여 금액을 구하면,
  • 자동차 ID가 1인 경우, 일일 대여 금액 25,000원에서 8% 할인율을 적용하고 30일을 곱하면 총 대여 금액은 690,000원
  • 자동차 ID가 4인 경우, 일일 대여 금액 12,000원에서 10% 할인율을 적용하고 30일을 곱하면 총 대여 금액은 324,000원
  • 자동차 ID가 5인 경우, 일일 대여 금액 22,000원에서 10% 할인율을 적용하고 30일을 곱하면 총 대여 금액은 621,000원이고, 대여 금액이 50만원 이상 200만원 미만인 경우에 대해서 대여 금액을 기준으로 내림차순, 자동차 종류를 기준으로 오름차순 및 자동차 ID를 기준으로 내림차순 정렬하면 다음과 같아야 합니다.
CAR_ID
CAR_TYPE
FEE
5
세단
690000
1
SUV
621000

주의사항

FEE의 경우 예시처럼 정수부분만 출력되어야 합니다.

2. 풀이

정답

SELECT * FROM (SELECT CAR_ID, CAR_TYPE, ROUND(DAILY_FEE*30*(SELECT 1-DISCOUNT_RATE/100 FROM CAR_RENTAL_COMPANY_DISCOUNT_PLAN WHERE CAR_TYPE = tb.CAR_TYPE AND DURATION_TYPE = '30일 이상'),0) 'FEE' FROM CAR_RENTAL_COMPANY_CAR tb WHERE CAR_TYPE IN ('세단', 'SUV') AND CAR_ID NOT IN (SELECT DISTINCT CAR_ID FROM CAR_RENTAL_COMPANY_RENTAL_HISTORY WHERE END_DATE > '2022-11-01 00:00:00')) tb2 WHERE FEE >= 500000 AND FEE < 2000000 ORDER BY FEE DESC, CAR_TYPE, CAR_ID DESC;
CAR_ID
CAR_TYPE
FEE
3
세단
1518000
23
세단
1380000

1) 차종 : 세단 or SUV 리스트

SELECT * FROM CAR_RENTAL_COMPANY_CAR WHERE CAR_TYPE IN ('세단', 'SUV');
car_id
car_type
daily_fee
options
2
SUV
148000
주차감지센서,후방카메라
3
세단
55000
스마트키,통풍시트,가죽시트
4
SUV
150000
주차감지센서,스마트키,열선시트,후방카메라,가죽시트
5
SUV
127000
주차감지센서,스마트키
9
SUV
84000
주차감지센서,스마트키
10
세단
162000
주차감지센서,스마트키,후방카메라
14
SUV
77000
주차감지센서,스마트키,열선시트,후방카메라
16
세단
168000
주차감지센서,열선시트,후방카메라
17
SUV
107000
스마트키,후방카메라
18
SUV
22000
주차감지센서,스마트키,열선시트,후방카메라
19
SUV
79000
주차감지센서,스마트키,열선시트,후방카메라
22
세단
186000
주차감지센서,스마트키,통풍시트
23
세단
50000
스마트키,네비게이션,열선시트
24
세단
184000
주차감지센서,스마트키,열선시트,후방카메라
25
세단
115000
주차감지센서,열선시트
26
SUV
126000
주차감지센서,통풍시트
27
SUV
23000
주차감지센서,스마트키,통풍시트
29
SUV
88000
주차감지센서,후방카메라

2) 대여 불가 리스트

SELECT * FROM CAR_RENTAL_COMPANY_RENTAL_HISTORY WHERE END_DATE > '2022-11-01 00:00:00';
history_id
car_id
start_date
end_date
507
26
2022-08-01 00:00:00
2022-11-09 00:00:00
560
16
2022-08-17 00:00:00
2022-11-15 00:00:00
569
29
2022-08-21 00:00:00
2022-11-29 00:00:00
606
22
2022-09-07 00:00:00
2022-12-06 00:00:00
620
28
2022-09-13 00:00:00
2022-12-22 00:00:00
648
5
2022-09-23 00:00:00
2022-11-02 00:00:00
657
11
2022-09-25 00:00:00
2023-01-03 00:00:00
660
27
2022-09-25 00:00:00
2022-12-24 00:00:00
674
17
2022-10-02 00:00:00
2022-11-06 00:00:00
675
9
2022-10-03 00:00:00
2023-01-04 00:00:00
678
19
2022-10-05 00:00:00
2022-11-14 00:00:00
681
12
2022-10-07 00:00:00
2022-11-16 00:00:00
685
2
2022-10-10 00:00:00
2023-01-11 00:00:00
687
7
2022-10-14 00:00:00
2022-11-23 00:00:00
702
15
2022-10-22 00:00:00
2022-11-06 00:00:00
707
10
2022-10-24 00:00:00
2023-01-25 00:00:00
712
18
2022-10-25 00:00:00
2023-01-26 00:00:00
714
8
2022-10-27 00:00:00
2022-11-06 00:00:00
720
6
2022-10-30 00:00:00
2022-11-02 00:00:00
721
21
2022-10-30 00:00:00
2022-11-02 00:00:00
722
1
2022-10-31 00:00:00
2022-11-30 00:00:00
724
20
2022-10-31 00:00:00
2022-12-10 00:00:00

3) 할인 정책

SELECT * FROM CAR_RENTAL_COMPANY_DISCOUNT_PLAN;
plan_id
car_type
duration_type
discount_rate
1
세단
7일 이상
5
2
세단
30일 이상
8
3
세단
90일 이상
12
4
SUV
7일 이상
3
5
SUV
30일 이상
5
6
SUV
90일 이상
10
7
승합차
7일 이상
5
8
승합차
30일 이상
10
9
승합차
90일 이상
15
10
트럭
7일 이상
5
11
트럭
30일 이상
8
12
트럭
90일 이상
15
13
리무진
7일 이상
4
14
리무진
30일 이상
8
15
리무진
90일 이상
20

4) 대여 가능 리스트 + 할인 적용 금액

SELECT CAR_ID, CAR_TYPE, ROUND(DAILY_FEE*30*(SELECT 1-DISCOUNT_RATE/100 FROM CAR_RENTAL_COMPANY_DISCOUNT_PLAN WHERE CAR_TYPE = tb.CAR_TYPE AND DURATION_TYPE = '30일 이상'),0) 'FEE' FROM CAR_RENTAL_COMPANY_CAR tb WHERE CAR_TYPE IN ('세단', 'SUV') AND CAR_ID NOT IN (SELECT DISTINCT CAR_ID FROM CAR_RENTAL_COMPANY_RENTAL_HISTORY WHERE END_DATE > '2022-11-01 00:00:00') ORDER BY FEE DESC, CAR_TYPE, CAR_ID DESC;
CAR_ID
CAR_TYPE
FEE
24
세단
5078400
4
SUV
4275000
25
세단
3174000
14
SUV
2194500
3
세단
1518000
23
세단
1380000
Share article