Notice
Recent Posts
Recent Comments
Link
| 일 | 월 | 화 | 수 | 목 | 금 | 토 |
|---|---|---|---|---|---|---|
| 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 8 | 9 | 10 | 11 | 12 | 13 | 14 |
| 15 | 16 | 17 | 18 | 19 | 20 | 21 |
| 22 | 23 | 24 | 25 | 26 | 27 | 28 |
Tags
- 프로그래머스 #문자열이 몇 번 등장하는지 세기 #알고리즘 #Java #자바 #코린이 #개발자 #study #공부 #성장
- 프로그래머스 #배열 회전시키기 #알고리즘 #Java #자바 #코린이 #개발자 #study #취준
- 파이썬 #input() #sys.stdin.readline() #공부 #study
- 프로그래머스 #1로 만들기 #알고리즘 #자바 #Java #코린이 #개발자 #study #공부 #성장
- 프로그래머스 #중복된 문자 제거 #알고리즘 #Java #자바 #코린이 #개발자 #study #공부 #성장
- 프로그래머스 #수열과 구간 쿼리 3 #알고리즘 #자바 #Java #코린이 #개발자 #study #공부 #성장
- 프로그래머스 #문자열 뒤집기 #알고리즘 #Java #자바 #코린이 #개발자 #study #공부 #성장
- 프로그래머스 #세로 읽기 #알고리즘 #개발자 #코린이 #study #성장 #Java #자바
- 프로그래머스 #배열만들기 5 #알고리즘 #study #Java #코린이 #개발자 #성장 #공부
- 프로그래머스 #합성수 찾기 #알고리즘 #Java #자바 #stiudy #코린이 #개발자 #공부 #성장
- 프로그래머스 #조건에 맞는 사용자와 총 거래금액 조회하기 #알고리즘 #Mysql #DB #쿼리문 #코린이 #개발자 #study #공부 #성장
- 프로그래머스 #오랜 기간 보호한 동물(1) #알고리즘 #MySQL #DB #쿼리문 #개발자 #study #성장 #코린이
- 프로그래머스 #등차수열의 특정한 항만 더하기 #알고리즘 #Java #자바 #코린이 #개발자 #study #공부
- 프로그래머스 #열의 길이를 2의 거듭제곱으로 만들기 #Java #자바 #알고리즘 #코린이 #개발자 #study #공부 #성장
- 프로그래머스 #푸드 파이트 대회 #알고리즘 #Java #자바 #코린이 #개발자 #study #취준
- 프로그래머스 #조건별로 분류하여 주문상태 출력하기 #MySQL #쿼리문 #알고리즘 #코린이 #개발자 #study #취준
- 프로그래머스 #카테고리 별 도서 판매량 집계하기 #알고리즘 #쿼리문 #MySQL #코린이 #개발자 #study #취준
- 프로그래머스 #소수 만들기 #알고리즘 #Java #자바 #코린이 #개발자 #study #취준
- 프로그래머스 #날짜 비교하기 #알고리즘 #자바 #Java #코린이 #개발자 #study #공부 #성장
- 프로그래머스 #조건에 맞게 수열 변환하기 1 #알고리즘 #자바 #Java #코린이 #개발자 #study #취준
- 백준 #
- 프로그래머스 #2차원으로 만들기 #알고리즘 #Java #자바 #study #코린이 #개발자 #공부 #성장
- 프로그래머스 #간단한 식 계산하기 #알고리즘 #Java #자바 #코린이 #개발자 #study #취준
- 프로그래머스 #특정 문자열로 끝나는 가장 긴 부분 문자열 찾기 #알고리즘 #자바 #Java #코린이 #개발자 #study #공부 #성장
- 프로그래머스 #길이에 따른 연산 #알고리즘 #자바 #Java #코린이 #개발자 #study #취준
- 프로그래머스 #있었는데요 없었습니다 #DB #MySQL #알고리즘 #쿼리문 #코린이 #개발자 #study #공부 #성장
- 프로그래머스 #할 일 목록 #알고리즘 #Java #자바 #코린이 #개발자 #study #취준
- 프로그래머스 #부분 문자열 이어 붙여 문자열 만들기 #알고리즘 #Java #자바 #코린이 #개발자 #study #취준
- 코린이 #개발자 #study
- 프로그래머스 #수열과 구간 쿼리1 #알고리즘 #자바 #Java #코린이 #개발자 #study #공부 #성장
Archives
- Today
- Total
luke
[프로그래머스] - 자동차 평균 대여 기간 구하기 (MySQL) 본문
문제 : https://school.programmers.co.kr/learn/courses/30/lessons/157342
프로그래머스
SW개발자를 위한 평가, 교육의 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
문제.


풀이.
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
이번 문제는 프로그래머스 "자동차 평균 대여 기간 구하기" MySQL 문제다.
평균 대여 기간을 구해야 하는데 START_DATE, END_DATE 사이의 날짜 차이를 알면 푸는데 크게 어려움 없을 거 같다.
그럼 바로 풀이해보겠다.
1. 우선 날짜 차이를 구하기 위해서 우리는 DATEDIFF()라는 함수를 사용해준다. 이 함수를 쉽게 말하면 큰 숫자에서 작은 수를 뺀다고 생각하면 될 거 같다.
2. 날짜 차이를 구해줬으면 평균을 구하기 위해 AVG() 함수를 DATEDIFF() 함수 밖에서 감싸준다. 여기서 중요한 건 우리가 +1을 해줘야 하는데 그 이유는 렌트 한 마지막 날까지 포함시켜야 하기 때문이다.
3. 다음으로 ROUND 함수를 사용해서 소수점 1 자릿수만 출력되게 해 주면 문제에서 원하는 평균값 설정이 완료된 거다.
4. CAR_ID를 그룹으로 지정해주고 문제에 평균일 수가 7일 이상인 값들을 출력해야 하니 HAVING 절로 조건 식을 만들어 준다.
5. 마지막으로 내림 차순으로 정렬해주면 끝이다.
'DB > 프로그래머스(MySQL)' 카테고리의 다른 글
| [프로그래머스] - 분기별 분화된 대장균의 개체 수 구하기 (MySQL) (0) | 2025.10.22 |
|---|---|
| [프로그래머스] - 노선별 평균 역 사이 거리 조회하기 (MySQL) (0) | 2025.10.17 |
| [프로그래머스] - 특정 물고기를 잡은 총 수 구하기 (MySQL) (0) | 2025.10.14 |
| [프로그래머스] - 조건에 맞는 사원 정보 조회하기 (MySQL) (0) | 2025.10.12 |
| [프로그래머스] - 조건에 부합하는 중고거래 상태 조회하기 (MySQL) (0) | 2025.10.11 |