> 데이터 베이스 > MySQL 튜토리얼 > 재귀 SQL 쿼리는 어떻게 일치 관계를 기반으로 제품을 효율적으로 그룹화할 수 있습니까?

재귀 SQL 쿼리는 어떻게 일치 관계를 기반으로 제품을 효율적으로 그룹화할 수 있습니까?

Patricia Arquette
풀어 주다: 2025-01-05 16:50:39
원래의
294명이 탐색했습니다.

How Can a Recursive SQL Query Efficiently Group Products Based on Matching Relationships?

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

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿