코딩테스트/SQL

[프로그래머스 Mysql] Lv4_특정 기간동안 대여 가능한 자동차들의 대여비용 구하기 - JOIN

PONI 2023. 7. 19. 13:53
반응형

 

https://school.programmers.co.kr/learn/courses/30/lessons/157339

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

📋 문제


자동차 종류가 '세단' 또는 'SUV' 인 자동차 중 2022년 11월 1일부터 2022년 11월 30일까지 대여 가능하고 30일간의 대여 금액이 50만원 이상 200만원 미만인 자동차에 대해서 자동차 ID, 자동차 종류, 대여 금액(컬럼명: FEE) 리스트를 출력하는 문제입니다.

 

📌풀이


SELECT 
    t.CAR_ID
    ,t.CAR_TYPE
    ,round(t.DAILY_FEE * 30 * (100 - p.DISCOUNT_RATE)/100) AS FEE
FROM CAR_RENTAL_COMPANY_CAR t
    JOIN CAR_RENTAL_COMPANY_DISCOUNT_PLAN p
        ON t.CAR_TYPE = p.CAR_TYPE AND p.DURATION_TYPE = '30일 이상'
WHERE t.CAR_TYPE IN ('세단', 'SUV')
    AND t.CAR_ID NOT IN (
        SELECT h.CAR_ID
        FROM CAR_RENTAL_COMPANY_RENTAL_HISTORY h
        WHERE h.END_DATE >= '2022-11-01' AND START_DATE <= '2022-11-30'
    )
HAVING FEE >= 500000 AND FEE < 2000000
ORDER BY FEE DESC, t.CAR_TYPE, t.CAR_ID DESC
;

 

📖 설명 


WHERE절 조건으로 타입을 설정한 후에 CAR_ID가 11월에 속한 CAR_ID만 조건 하기 위해  NOT IN 으로 기간을 지정

SELECT절 FEE 컬럼을 정수로 출력하기 위해 round 함수 사용

HAVING 에서 조건에 맞는 FEE 조건 지정

 * round 함수 : round(number, [precision])

반응형