집 >데이터 베이스 >MySQL 튜토리얼 >최소 제품 ID를 기준으로 재귀 SQL 쿼리 그룹 제품 일치를 어떻게 할 수 있습니까?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!