>데이터 베이스 >MySQL 튜토리얼 >최소 제품 ID를 기준으로 재귀 SQL 쿼리 그룹 제품 일치를 어떻게 할 수 있습니까?

최소 제품 ID를 기준으로 재귀 SQL 쿼리 그룹 제품 일치를 어떻게 할 수 있습니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-05 14:33:45235검색

How Can Recursive SQL Queries Group Product Matches Based on Minimum Product ID?

SQL Server의 재귀 쿼리

데이터 분석가가 일치하는 제품이 포함된 테이블을 원하는 그룹화 테이블로 변환하는 데 어려움을 겪고 있습니다. 목표는 각 그룹이 구성 제품의 최소 제품 ID로 표시되는 '그룹'이라는 새 테이블을 파생시키는 것입니다.

이를 달성하기 위해 SQL의 재귀 기능을 활용할 수 있습니다. 다음은 공통 테이블 표현식(CTE)을 사용하는 솔루션입니다.

;WITH CTE
AS
(
    SELECT DISTINCT
        M1.Product_ID Group_ID,
        M1.Product_ID
    FROM matches M1
        LEFT JOIN matches M2
            ON M1.Product_Id = M2.matching_Product_Id
    WHERE M2.matching_Product_Id IS NULL
    UNION ALL
    SELECT
        C.Group_ID,
        M.matching_Product_Id
    FROM CTE C
        JOIN matches M
            ON C.Product_ID = M.Product_ID
)
SELECT * FROM CTE ORDER BY Group_ID

CTE는 일치하는 제품이 없는 행으로 시작하는 재귀 쿼리를 정의합니다. 그런 다음 일치하는 추가 제품을 식별하고 최소 제품 ID를 기준으로 그룹화합니다. 재귀 깊이는 OPTION(MAXRECURSION) 절을 사용하여 제어할 수 있습니다.

이 솔루션은 지정된 기준에 따라 일치하는 제품을 그룹으로 효과적으로 집계합니다.

위 내용은 최소 제품 ID를 기준으로 재귀 SQL 쿼리 그룹 제품 일치를 어떻게 할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.