[프로그래머스][SQL] 자동차 대여 기록에서 장기/단기 대여 구분하기

Eunding·2024년 2월 27일
0

SQL 고득점 Kit

목록 보기
46/62

자동차 대여 기록에서 장기/단기 대여 구분하기

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

DATEDIFF(날짜1, 날짜2)

  • 날짜1과 날짜2의 차이를 구하는 메소드이다.
  • 처음에 END_DATE - START_DATE 이런 식으로 하다가 틀렸다.
profile
안녕하세요~

0개의 댓글