>데이터 베이스 >MySQL 튜토리얼 >재귀 CTE는 일치하는 쌍을 기반으로 SQL Server의 제품 그룹을 어떻게 식별할 수 있습니까?

재귀 CTE는 일치하는 쌍을 기반으로 SQL Server의 제품 그룹을 어떻게 식별할 수 있습니까?

Patricia Arquette
Patricia Arquette원래의
2025-01-05 07:32:39863검색

How Can Recursive CTEs Identify Product Groups in SQL Server Based on Matching Pairs?

SQL Server의 재귀 쿼리

'matches'라는 테이블은 한 제품이 다른 제품과 일치하는 제품 쌍을 저장합니다. 목표는 서로 일치하는 모든 제품으로 구성된 제품 그룹을 식별하는 '그룹' 테이블을 생성하는 것입니다. 그룹 ID는 각 그룹의 최소 제품 ID를 저장해야 합니다.

재귀 CTE 솔루션

이를 달성하기 위해 다음과 같이 재귀 공통 테이블 표현식(CTE)을 사용할 수 있습니다.

WITH CTE AS (
    SELECT DISTINCT
        M1.Product_ID AS Group_ID,
        M1.Product_ID
    FROM matches AS M1
    LEFT JOIN matches AS 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 AS C
    JOIN matches AS M
        ON C.Product_ID = M.Product_ID
)
SELECT * FROM CTE
ORDER BY Group_ID;

CTE는 서로 직간접적으로 관련된 모든 제품을 재귀적으로 찾습니다. 일치하는 제품이 없는 제품을 식별하는 것부터 시작됩니다(Group_ID는 자체 Product_ID입니다). 그런 다음 각 그룹에 대해 일치하는 모든 제품을 검색하여 CTE에 추가합니다. UNION ALL 절은 초기 쿼리 결과와 후속 반복 결과를 결합하여 일치하는 모든 제품을 찾도록 합니다.

ORDER BY Group_ID 절은 그룹 ID의 오름차순으로 결과를 정렬하여 쉽게 결과를 제공합니다. 제품 그룹과 해당 구성원을 식별하는 방법입니다.

재귀 사용자 정의 깊이

OPTION(MAXRECURSION n) 절을 사용하면 최대 재귀 깊이를 제어할 수 있어 제품 관계가 복잡한 경우 과도한 재귀를 방지하는 데 도움이 됩니다.

데모

자세한 데모는 SQL Fiddle을 참조하세요. 예:

https://www.sqlfiddle.com/#!17/d4e0f/20332

위 내용은 재귀 CTE는 일치하는 쌍을 기반으로 SQL Server의 제품 그룹을 어떻게 식별할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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