SQL 코드카타 65번 - 우유와 요거트가 담긴 장바구니
우유(Milk)와 요거트(Yogurt)를 동시에 구입한 장바구니가 있는지 알아보려 합니다. 우유와 요거트를 동시에 구입한 장바구니의 아이디를 조회하는 SQL 문을 작성해주세요. 이때 결과는 장바구니의 아이디 순으로 나와야 합니다.

SELECT MILK.CART_ID
FROM (SELECT CART_ID
FROM CART_PRODUCTS
WHERE NAME = 'Milk') MILK
INNER JOIN (SELECT CART_ID
FROM CART_PRODUCTS
WHERE NAME = 'Yogurt') YOGURT
ON MILK.CART_ID = YOGURT.CART_ID
SELECT CART_ID, GROUP_CONCAT(NAME)
FROM CART_PRODUCTS
GROUP BY CART_ID
위 코드를 실행하면

위 테이블과 같이 그룹 (CART_ID) 별 NAME이 연결되어 반환된다.
SELECT CART_ID
FROM CART_PRODUCTS
GROUP BY CART_ID
HAVING GROUP_CONCAT(NAME) LIKE '%Milk%'
AND GROUP_CONCAT(NAME) LIKE '%Yogurt%'
ORDER BY 1
CART_ID로 GROUP BY를 실행하였기 때문에 위 쿼리를 통해 나오는 CART_ID는 개별 데이터가 아닌 그룹 이름이다. 따라서 조건 적용을 위해 HAVING을 사용해야 한다.