우당탕탕 개발일지
[SQL] 프로그래머스 String, Date : 자동차 대여 기록에서 장기/단기 대여 구분하기(level 1) 본문
💡문제 링크
💡SQL 코드 설계
CAR_RENTAL_COMPANY_RENTAL_HISTORY 테이블에서 대여 시작일이 2022년 9월에 속하는 대여 기록에 대해서 대여 기간이 30일 이상이면 '장기 대여' 그렇지 않으면 '단기 대여' 로 표시하는 컬럼(컬럼명: RENT_TYPE)을 추가하여 대여기록을 출력하는 SQL문을 작성해주세요. 결과는 대여 기록 ID를 기준으로 내림차순 정렬해주세요.
1. 대여 시작일이 2022년 9월에 속하는 대여 기록에 대해서(WHERE)
2. 대여 기간이 30일 이상이면 '장기 대여' 그렇지 않으면 '단기 대여' 로 표시하는 컬럼(컬럼명: RENT_TYPE)을 추가(CASE WHEN)
3. 결과는 대여 기록 ID를 기준으로 내림차순 정렬(ORDER BY)
💡SQL 코드
-- 코드를 입력하세요
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
💡기억할 내용
1. 기간이 30일 이상이면 날짜 차이가 29 이상이면 된다
예를 들어서 2월 10일이랑 2월 15일이 주어졌으면 기간은 6일이고, 날짜 차이는 5일!
2. CASE WHEN 조건절 THEN 참일 때 값 ELSE 거짓일 때 값 END AS 열 이름
'SQL' 카테고리의 다른 글
[SQL] 프로그래머스 String, Date : 자동차 평균 대여 기간 구하기(level 2) (0) | 2024.02.22 |
---|---|
[SQL] 프로그래머스 String, Date : 조회수가 가장 많은 중고거래 게시판의 첨부파일 조회하기 (level 3)⭐ (0) | 2024.02.22 |
[SQL] 프로그래머스 SUM, MAX, MIN : 조건에 맞는 아이템들의 가격의 총합 구하기 (level 2) (0) | 2024.02.19 |
[SQL] 프로그래머스 SELECT : 업그레이드 된 아이템 구하기 (level 2) ⭐ (0) | 2024.02.19 |
[SQL] 프로그래머스 GROUP BY : 저자 별 카테고리 별 매출액 집계하기 (level 4) (0) | 2024.02.19 |