[문제]
https://school.programmers.co.kr/learn/courses/30/lessons/157339
[풀이]
1. CAR_TYPE이 세단이거나 SUV
2. 11월 동안 대여 가능해야 한다.
3. DURATION_TYPE이 '30일 이상' 인 경우, 30일 동안의 대여비가 50만원 이상 200만원 미만이어야 한다.
계산한 후의 결과값인 FEE를 이용하려면 HAVING을 써야 한다. WHERE를 이용할 경우 FEE값이 계산되지 않아 이를 인식하지 못함에 주의!
[코드]
SELECT T1.CAR_ID, T1.CAR_TYPE, ROUND(DAILY_FEE * 30 * (100 - DISCOUNT_RATE)/100) AS FEE
FROM CAR_RENTAL_COMPANY_CAR AS T1
JOIN CAR_RENTAL_COMPANY_DISCOUNT_PLAN AS T2
ON T1.CAR_TYPE = T2.CAR_TYPE AND T2.DURATION_TYPE = '30일 이상'
WHERE T1.CAR_TYPE IN ('세단', 'SUV')
AND T1.CAR_ID NOT IN (
SELECT CAR_ID
FROM CAR_RENTAL_COMPANY_RENTAL_HISTORY
WHERE END_DATE >= '2022-11-01' AND START_DATE <= '2022-11-30'
)
HAVING FEE >= 500000 AND FEE < 2000000
ORDER BY FEE DESC, T1.CAR_TYPE ASC, T1.CAR_ID DESC;
'알고리즘 공부 및 문제 풀이 > 프로그래머스(PRO)' 카테고리의 다른 글
[pro] 프로그래머스 SQL level4 입양 시각 구하기(2) - GROUP BY, RECURSIVE CTE (0) | 2023.04.28 |
---|---|
[pro] 프로그래머스 SQL level4 년, 월, 성별 별 상품 구매 회원 수 구하기 - GROUP BY (0) | 2023.04.28 |
[pro] 프로그래머스 SQL level2 카테고리 별 상품 개수 구하기 - String (0) | 2023.04.28 |
[pro] 프로그래머스 SQL level3 대여 횟수가 많은 자동차들의 월별 대여 횟수 구하기 - GROUP BY (0) | 2023.04.27 |
[pro] 프로그래머스 SQL level3 자동차 대여 기록에서 대여중 / 대여 가능 여부 구분하기 - GROUP BY (0) | 2023.04.27 |