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
- 내일배움일지
- 아티클스터디
- f-string
- AB테스트
- Join
- map
- 다중공선성
- 내일배움캠프
- 태블로
- 데이터시각화
- Til
- Max
- 내배캠_학습기록
- 시각화
- SQLD
- 프로그래머스
- 가설검정
- 통계학
- Set
- ★
- 이중for문
- 데이터전처리
- 한줄for문
- SQL
- 선형회귀
- python
- Leetcode
- 리스트
- 반복문
- DATE_SUB
Archives
- Today
- Total
노력에는 지름길이 없으니까요
프로그래머스 - 식품분류별 가장 비싼 식품의 정보 조회하기 본문
728x90
해결일 | 언어 | 레벨 | 테스트명 |
20240710 | SQL | level 4 | 식품분류별 가장 비싼 식품의 정보 조회하기 |
링크 : https://school.programmers.co.kr/learn/courses/30/lessons/131116
내 코드
SELECT
A.CATEGORY,
A.PRICE MAX_PRICE,
PRODUCT_NAME
FROM FOOD_PRODUCT FP
JOIN (SELECT CATEGORY, MAX(PRICE) PRICE
FROM FOOD_PRODUCT
GROUP BY CATEGORY) A
USING (CATEGORY)
WHERE 1=1
AND FP.CATEGORY = A.CATEGORY
AND FP.PRICE = A.PRICE
GROUP BY CATEGORY
HAVING CATEGORY IN ('과자', '국', '김치', '식용유')
ORDER BY 2 DESC
개선점: 처음에 조인을 CATEGORY 말고 PRODUCT_ID로 해서 계속 하나의 값만 추출됐는데...
애초에 A 테이블에서 GROUP BY CAT~으로 묶는 과정에서 PRODUCT_ID의 의미가 없어졌음을 깨달았다
사실 이 문제는 한 세번 다시 풀었기 때문에 ㅋㅋㅋ 이제서야 당당하게 올리게 되어 기쁠 따름이다
베스트 코드
with shortlist as (
SELECT category, max(price) as max_price, product_name
from food_product
where category in ('과자','국','김치','식용유')
group by 1, 3
order by 2 desc) -- 2차 group by에서 대표값으로 사용하기 위해서
select *
from shortlist
group by 1;
SELECT A.CATEGORY, A.MAX_PRICE, A.PRODUCT_NAME
FROM (SELECT CATEGORY, PRICE,
MAX(PRICE) OVER (PARTITION BY CATEGORY) MAX_PRICE, PRODUCT_NAME
FROM FOOD_PRODUCT
WHERE CATEGORY IN ('과자', '국', '김치', '식용유')) A
WHERE A.MAX_PRICE = A.PRICE
ORDER BY 2 DESC;
윈도우 함수를 사용한 예시를 찾아왔다...
PARTITION BY 잘 사용하고 싶다
728x90
반응형
'SQL > 프로그래머스' 카테고리의 다른 글
프로그래머스 - 배열 만들기 1 (0) | 2024.07.12 |
---|---|
프로그래머스 - 가격대 별 상품 개수 구하기 (0) | 2024.07.10 |
프로그래머스 - 저자 별 카테고리 별 매출액 집계하기 (0) | 2024.07.03 |
프로그래머스 - 년, 월, 성별 별 상품 구매 회원 수 구하기 (0) | 2024.07.03 |
프로그래머스 - 5월 식품들의 총매출 조회하기 (0) | 2024.07.02 |