https://school.programmers.co.kr/learn/courses/30/lessons/151138
CAR_RENTAL_COMPANY_RENTAL_HISTORY 테이블에서 대여 시작일이 2022년 9월에 속하는 대여 기록에 대해서 대여 기간이 30일 이상이면 '장기 대여' 그렇지 않으면 '단기 대여' 로 표시하는 컬럼(컬럼명: RENT_TYPE)을 추가하여 대여기록을 출력하는 SQL문을 작성해주세요. 결과는 대여 기록 ID를 기준으로 내림차순 정렬해주세요.
SELECT HISTORY_ID, CAR_ID, DATE_FORMAT(START_DATE, '%Y-%m-%d') AS START_DATE, DATE_FORMAT(END_DATE, '%Y-%m-%d') AS END_DATE,
(CASE WHEN DATEDIFF(END_DATE, START_DATE) >= 29
THEN '장기 대여'
ELSE '단기 대여'
END) AS RENT_TYPE
FROM CAR_RENTAL_COMPANY_RENTAL_HISTORY
WHERE START_DATE LIKE '2022-09%'
ORDER BY HISTORY_ID DESC;
문제에서 30일 이상이면 장기대여라고 해서 쿼리 쓸 때 >= 30 이렇게 찾았다가 틀렸다.
생각해보면 start_date = 2022-01-01, end_date = 2022-01-02 이면 DATEDIFF(end_date, start_date) = 1 이지만 사실 2일을 빌린 것이므로 >= 29로 해줘야 한다.
DATEDIFF(날짜1, 날짜2)