본문 바로가기
데이터분석 공부하기/프로그래머스 SQL 고득점 키트

[SQL/프로그래머스 SQL 고득점 kit] 자동차 대여 기록에서 장기/단기 대여 구분하기(Level 1)

by Confident Beginner 2023. 1. 25.

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

 

프로그래머스

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

programmers.co.kr

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)+1 >=30 THEN '장기 대여' ELSE '단기 대여' END AS RENT_TYPE
    # ,DATEDIFF(end_date, start_date)+1  ---이렇게 적어두면 장기/단기가 잘 들어갔는지 확인하기 편함
    
FROM CAR_RENTAL_COMPANY_RENTAL_HISTORY
WHERE MONTH(start_date) = '09'
ORDER BY history_id DESC
새로 배운 함수
  • DATE_FORMAT(START_DATE, '%Y-%m-%d') : 2020-01-01 형식으로 반환

 

  • DATEDIFF(B, A) : B에서 A를 뺀 날짜 일수를 반환

ex) DATEDIFF(2020-01-16 , 2020-01-01 ) => 15
문제에 따르면 2020-01-01~2020-01-16은 16일로 계산하기 때문에 DATEDIFF 에 +1을 했다.

오답노트
  • '장기 대여'를 '장기대여'로 적었다. 정답에서 요구한 형식의 띄어쓰기나 디테일한 부분을 잘 확인하자!