>데이터 베이스 >MySQL 튜토리얼 >SQL Server의 재귀 CTE는 어떻게 범주와 해당 상위 경로를 검색할 수 있습니까?

SQL Server의 재귀 CTE는 어떻게 범주와 해당 상위 경로를 검색할 수 있습니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-15 11:30:44563검색

How Can Recursive CTEs in SQL Server Retrieve a Category and its Ancestor Path?

SQL Server에서 재귀 공통 테이블 표현식(CTE)을 사용한 자체 참조 쿼리

소개

관계형 데이터베이스에서 자체 참조 쿼리는 단일 테이블의 계층 관계를 탐색하는 강력한 기술입니다. SQL Server는 이러한 목적을 위해 CTE(공통 테이블 식)를 제공하여 효율적이고 표현력이 풍부한 재귀 쿼리를 가능하게 합니다.

질문

ID, 이름, ParentId 열이 포함된 단순화된 '범주' 테이블을 생각해 보세요. 테이블은 다음 예에 표시된 것처럼 불확실한 범주 계층 구조를 지원합니다.

<code>Id     Name       ParentId
1      Business   NULL
2      Laptops    1
3      Asus       2</code>

목표는 지정된 카테고리(예: "비즈니스 노트북")를 검색할 뿐만 아니라 모든 상위 카테고리의 쉼표로 구분된 목록을 제공하는 쿼리를 구성하는 것입니다.

해결책: 재귀적 CTE

이 문제를 해결하기 위해 재귀적 CTE를 사용할 수 있습니다. 가장 바깥쪽 CTE는 재귀의 시작점을 정의하고 재귀 용어는 확장된 계층 구조의 논리를 정의합니다.

<code>WITH CTE AS (
    SELECT Id, Name, Name AS Path, ParentId
    FROM Categories 
    WHERE ParentId IS NULL
    UNION ALL
    SELECT t.Id, t.Name, cast(cte.Path + ',' + t.Name as varchar(100)), t.ParentId
    FROM Categories t
    INNER JOIN CTE ON t.ParentId = CTE.Id
)</code>

쿼리

지정된 카테고리와 해당 상위 카테고리를 검색하려면 다음과 같은 간단한 쿼리를 사용합니다.

<code>SELECT Id, Name, Path
FROM CTE
WHERE Name = 'Business Laptops'</code>

결과

쿼리는 다음 결과를 반환합니다.

<code>Id     Name       Path
2      Laptops    Business,Laptops</code>

이 예에서 "Business Laptops"는 "Business"의 하위 항목인 "Laptops"의 하위 항목입니다. 경로 열은 루트 범주로 돌아가는 완전한 계층적 경로를 제공합니다.

결론

SQL Server의 재귀 CTE는 테이블의 계층 관계를 탐색하는 우아하고 효율적인 방법을 제공합니다. 재귀의 힘을 활용하면 복잡한 쿼리를 구성하여 계층적 데이터 구조에서 귀중한 통찰력을 추출할 수 있습니다.

위 내용은 SQL Server의 재귀 CTE는 어떻게 범주와 해당 상위 경로를 검색할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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