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 중국어 웹사이트의 기타 관련 기사를 참조하세요!