[SQL] 우유와 요거트가 담긴 장바구니

순동·2022년 5월 20일
0

✅ 우유와 요거트가 담긴 장바구니


📝 문제

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

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


💻 풀이

SELECT DISTINCT(M.CART_ID)
FROM
    (SELECT CART_ID FROM CART_PRODUCTS WHERE NAME = "Milk") AS M,
    (SELECT CART_ID FROM CART_PRODUCTS WHERE NAME = "Yogurt") AS Y
WHERE M.CART_ID = Y.CART_ID
ORDER BY M.CART_ID ASC;

💡 Idea

MilkYogurt를 둘 다 구매한 CART_ID를 조회한다.

FROM절에 Milk를 구입한 CART_IDYogurt를 구입한 CART_ID를 나타내는 서브쿼리를 두 개 만든다.

Milk와 Yogurt를 모두 구입했다면 위의 두 서브쿼리의 CART_ID는 같은 값이어야 한다.

위 내용을 WHERE절에 조건으로 설정하고 중복값을 제외한 CART_ID를 출력하면 된다.

0개의 댓글

관련 채용 정보

Powered by GraphCDN, the GraphQL CDN