250x250
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 | 29 | 30 | 31 |
Tags
- Set
- 프로그래머스
- SQLD
- 선형회귀
- ★
- Join
- 한줄for문
- 다중공선성
- 시각화
- DATE_SUB
- 아티클스터디
- 가설검정
- 내배캠_학습기록
- 내일배움캠프
- 리스트
- Til
- 태블로
- f-string
- 데이터시각화
- 반복문
- map
- Max
- 데이터전처리
- Leetcode
- 내일배움일지
- AB테스트
- python
- SQL
- 통계학
- 이중for문
Archives
- Today
- Total
노력에는 지름길이 없으니까요
프로그래머스 - 배열 만들기 1 본문
728x90
해결일 | 언어 | 레벨 | 테스트명 |
20240712 | SQL | level 3 | 배열 만들기 1 |
링크 : https://school.programmers.co.kr/learn/courses/30/lessons/151139#qna
내 코드
SELECT
MONTH(START_DATE) MONTH
,CAR_ID
,COUNT(1) RECORDS
FROM CAR_RENTAL_COMPANY_RENTAL_HISTORY
WHERE 1=1
AND MONTH(START_DATE) BETWEEN 8 AND 10 #이 부분에서 조금 헤맸다
AND CAR_ID IN (SELECT
CAR_ID
FROM CAR_RENTAL_COMPANY_RENTAL_HISTORY
WHERE YEAR(START_DATE) = 2022
AND MONTH(START_DATE) BETWEEN 8 AND 10
GROUP BY 1
HAVING COUNT(*) >= 5)
GROUP BY 1,2
HAVING RECORDS != 0
ORDER BY 1, 2 DESC
개선점:
START_DATE가 8월과 10월 사이 COUNT가 5 이상인 CAR_ID를 출력하는 서브쿼리와
그 중에서 또 START_DATE가 8월과 10월 사이의 개수를 출력하는 쿼리를 짜야하기 때문에
양쪽 다 날짜 조건이 포함되어야 하는데...
그걸 놓쳐서 시간을 조금 오래 썼다
베스트 코드
WITH HIST AS (
SELECT CAR_ID, HISTORY_ID, MONTH(START_DATE) MONTH
FROM CAR_RENTAL_COMPANY_RENTAL_HISTORY
WHERE YEAR(START_DATE) = 2022
AND MONTH(START_DATE) BETWEEN '08' AND '10'
), HIST_LIMIT AS (
SELECT CAR_ID
FROM HIST
GROUP BY CAR_ID
HAVING COUNT(HISTORY_ID) >= 5
)
SELECT MONTH, CAR_ID, COUNT(HISTORY_ID) RECORDS
FROM HIST
WHERE CAR_ID IN (SELECT CAR_ID FROM HIST_LIMIT)
GROUP BY MONTH, CAR_ID
HAVING COUNT(HISTORY_ID) > 0
ORDER BY MONTH, CAR_ID DESC;
WITH로 일시적 테이블을 만들 때 2개 이상을 만들고 싶으면 위의 방법을 사용하면 될 것 같다.
참고하고 싶어서 가져왔다.
728x90
반응형
'SQL > 프로그래머스' 카테고리의 다른 글
프로그래머스 - 우유와 요거트가 담긴 장바구니 (0) | 2024.07.16 |
---|---|
프로그래머스 - 그룹별 조건에 맞는 식당 목록 출력하기 (1) | 2024.07.15 |
프로그래머스 - 가격대 별 상품 개수 구하기 (0) | 2024.07.10 |
프로그래머스 - 식품분류별 가장 비싼 식품의 정보 조회하기 (0) | 2024.07.10 |
프로그래머스 - 저자 별 카테고리 별 매출액 집계하기 (0) | 2024.07.03 |