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
FROM CAR_RENTAL_COMPANY_RENTAL_HISTORY
WHERE MONTH(START_DATE) = 9
ORDER BY HISTORY_ID DESC;
1. 가져와야 되는 거 가져오고 DATE_FORMAT()으로 날짜 형식 맞추기
2. DATEDIFF() 사용하여 날짜 수 계산함 (9월 28일에 빌려서 동일 날짜에 반납해도 1일로 간주하므로 +1 필요함)
3. CASE WHEN 조건문 THEN 결과 ELSE 그외 결과 사용
4. 가져오는 테이블 명시
5. 9월에 빌린 것만 가져오기
6. 대여 기록 ID를 기준으로 내림차순 정렬
'코딩테스트 수련일지 > 프로그래머스 MySQL' 카테고리의 다른 글
프로그래머스 | 상품 별 오프라인 매출 구하기 (0) | 2023.03.15 |
---|---|
프로그래머스 | 조건에 부합하는 중고거래 댓글 조회하기 (0) | 2023.03.14 |
프로그래머스 | 과일로 만든 아이스크림 고르기 (0) | 2023.03.12 |
프로그래머스 | 조건에 맞는 도서와 저자 리스트 출력하기 (0) | 2023.03.11 |
프로그래머스 | 자동차 종류 별 특정 옵션이 포함된 자동차 수 구하기 (0) | 2023.03.10 |