본문 바로가기
내일배움캠프/Daily Routine (SQL)

[내일배움캠프] SQL Daily Routine 65. 우유와 요거트가 담긴 장바구니

by TIP__ 2024. 11. 15.

안녕하세요.
65회차 과제 우유와 요거트가 담긴 장바구니입니다.


문제 설명

CART_PRODUCTS 테이블은 장바구니에 담긴 상품 정보를 담은 테이블입니다.
CART_PRODUCTS 테이블의 구조는 다음과 같으며, ID, CART_ID, NAME, PRICE는 각각 테이블의 아이디, 장바구니의 아이디, 상품 종류, 가격을 나타냅니다.

문제

데이터 분석 팀에서는 우유(Milk)와 요거트(Yogurt)를 동시에 구입한 장바구니가 있는지 알아보려 합니다.
우유와 요거트를 동시에 구입한 장바구니의 아이디를 조회하는 SQL 문을 작성해주세요.

이때 결과는 장바구니의 아이디 순으로 나와야 합니다.


풀이

-- cart_id
-- 우유와 요거트를 동시에 구입
-- cart_id asc
select cart_id
from(
select cart_id, name, count(*) over (partition by cart_id) as cnt_cart_id
from cart_products
group by cart_id, name
having name in("Yogurt", "Milk")
    ) a
where cnt_cart_id >= 2
group by cart_id
order by cart_id asc

저처럼 개발을 처음 접하시는 분들에게 이 글이 조금이나마 도움이 되길 바랍니다.

댓글