[SQL] 프로그래머스 - 우유와 요거트가 담긴 장바구니

do_large·2020년 10월 18일
0

알고리즘

목록 보기
12/50
post-thumbnail

문제설명

CART_PRODUCTS 테이블은 장바구니에 담긴 상품 정보를 담은 테이블입니다. CART_PRODUCTS 테이블의 구조는 다음과 같으며, ID, CART_ID, NAME, PRICE는 각각 테이블의 아이디, 장바구니의 아이디, 상품 종류, 가격을 나타냅니다.
데이터 분석 팀에서는 우유(Milk)와 요거트(Yogurt)를 동시에 구입한 장바구니가 있는지 알아보려 합니다. 우유와 요거트를 동시에 구입한 장바구니의 아이디를 조회하는 SQL 문을 작성해주세요. 이때 결과는 장바구니의 아이디 순으로 나와야 합니다.

예시

결과

코드

SELECT DISTINCT CART_ID 
FROM CART_PRODUCTS
WHERE CART_ID IN (SELECT CART_ID FROM CART_PRODUCTS WHERE NAME = "Yogurt")
AND CART_ID IN (SELECT CART_ID FROM CART_PRODUCTS WHERE NAME = "Milk")
ORDER BY CART_ID ASC

SELECT문 구문 형식

SELECT select_list

[ INTO new_table ]

[ FROM table_source ]

[ WHERE search_condition ]

[ GROUP BY group_by_expression ]

[ HAVING search_condition ]

[ ORDER BY order_expression [ ASC | DESC ] ]

핵심

where 일치하길원하는 컬럼명 in (조건1, 조건2, 조건3...)
where 뒤에 써준 컬럼과 in 뒤로 나열한 조건들 중 일치하는 row를 가져오게 된다.
여기서 나열한 조건들은 or조건으로 검색하게 된다.

0개의 댓글