SQL Server에서 제품 그룹을 설정하기 위한 재귀 쿼리
데이터 분석의 일반적인 작업은 관련 엔터티를 식별하고 그룹화하는 것입니다. 이 특정 시나리오의 목표는 일치하는 제품 테이블을 처리하고 이를 각 행이 제품 그룹을 나타내는 별도의 테이블에 저장하는 것입니다. 제품 그룹은 제품 간의 "일치" 관계에 의해 결정됩니다.
이를 달성하기 위해 SQL Server의 CTE(공용 테이블 표현식)를 사용하는 재귀 쿼리를 사용할 수 있습니다. 재귀 쿼리를 사용하면 쿼리가 자체 출력을 참조하여 복잡한 조인 및 트리형 구조를 구현할 수 있습니다.
"CTE"라고 불리는 CTE는 먼저 다음을 선택하여 각 그룹의 루트 노드를 식별합니다. 일치하는 제품이 없는 각 제품의 최소 제품 ID입니다. 그런 다음 일치 테이블과 재귀적으로 조인하여 각 그룹의 나머지 제품을 식별합니다.
마지막 쿼리는 CTE에서 데이터를 검색하고 그룹 ID를 기준으로 결과를 정렬합니다. OPTION(MAXRECURSION n) 절을 지정하면 허용되는 최대 재귀 깊이를 제어하여 쿼리가 무한 루프에 들어가지 않도록 할 수 있습니다.
다음은 재귀 쿼리에 대한 SQL 코드입니다.
;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;
이 재귀 쿼리를 사용하면 일치 관계를 기준으로 제품을 효과적으로 그룹화하고 결과를 별도의 테이블에 저장할 수 있습니다. 분석합니다.
위 내용은 재귀 SQL 쿼리는 어떻게 일치 관계를 기반으로 제품을 효율적으로 그룹화할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!