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