[SQL문제 풀기] (68) 자동차 평균 대여 기간 구하기

KangHo Lee's avatar
Feb 08, 2025
[SQL문제 풀기] (68) 자동차 평균 대여 기간 구하기

문제 설명

다음은 어느 자동차 대여 회사의 자동차 대여 기록 정보를 담은 CAR_RENTAL_COMPANY_RENTAL_HISTORY 테이블입니다. CAR_RENTAL_COMPANY_RENTAL_HISTORY 테이블은 아래와 같은 구조로 되어있으며, HISTORY_IDCAR_IDSTART_DATEEND_DATE 는 각각 자동차 대여 기록 ID, 자동차 ID, 대여 시작일, 대여 종료일을 나타냅니다.
Column name
Type
Nullable
HISTORY_ID
INTEGER
FALSE
CAR_ID
INTEGER
FALSE
START_DATE
DATE
FALSE
END_DATE
DATE
FALSE

문제

CAR_RENTAL_COMPANY_RENTAL_HISTORY 테이블에서 평균 대여 기간이 7일 이상인 자동차들의 자동차 ID와 평균 대여 기간(컬럼명: AVERAGE_DURATION) 리스트를 출력하는 SQL문을 작성해주세요. 평균 대여 기간은 소수점 두번째 자리에서 반올림하고, 결과는 평균 대여 기간을 기준으로 내림차순 정렬해주시고, 평균 대여 기간이 같으면 자동차 ID를 기준으로 내림차순 정렬해주세요.

해답

SELECT CAR_ID, ROUND(AVG(DATEDIFF(END_DATE, START_DATE) + 1), 1) AS AVERAGE_DURATION FROM CAR_RENTAL_COMPANY_RENTAL_HISTORY GROUP BY CAR_ID HAVING AVERAGE_DURATION >= 7 ORDER BY AVERAGE_DURATION DESC, CAR_ID DESC;
  • GROUP BY 가 WHERE 절 다음에 오기 때문에 WHERE 절에 집계 함수를 쓸 수 없습니다.
  • 당일 대여해서 당일 반납할 경우 대여 기간이 1일 이므로 DATEDIFF(END_DATE, START_DATE) + 1
로 해줘야 합니다.
Share article

devleekangho