[SQL] GROUP_CONCAT

·2024년 12월 2일

SQL

목록 보기
3/23

SQL 코드카타 65번 - 우유와 요거트가 담긴 장바구니

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

JOIN으로 풀기

  • Milk 구매 기록이 있는 CART_ID와 Yogurt 구매 기록이 있는 CART_ID를 JOIN
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

GROUP_CONCAT

  • 조건에 맞는 값들을 묶어서 출력
  • GROUP_CONCAT(칼럼명)
    • MAX()는 최댓값을, AVG()는 평균을, SUM()은 합계를 반환하는 것처럼 해당 그룹의 값들을 이어붙여서 출력
  • 구분자를 변경하고 싶다면 GROUP_CONCAT(칼럼명 SEPARATOR '-')

예시

SELECT CART_ID, GROUP_CONCAT(NAME)
FROM CART_PRODUCTS
GROUP BY CART_ID

위 코드를 실행하면

위 테이블과 같이 그룹 (CART_ID) 별 NAME이 연결되어 반환된다.

GROUP_CONCAT으로 풀기

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을 사용해야 한다.

profile
To Dare is To Do

0개의 댓글