>데이터 베이스 >MySQL 튜토리얼 >SQL Server 2005의 자체 참조 테이블에서 계층적 데이터를 효율적으로 검색하려면 어떻게 해야 합니까?

SQL Server 2005의 자체 참조 테이블에서 계층적 데이터를 효율적으로 검색하려면 어떻게 해야 합니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-25 08:48:11290검색

How Can I Efficiently Retrieve Hierarchical Data from a Self-Referencing Table in SQL Server 2005?

SQL Server 2005에서 계층적 데이터 탐색

SQL Server 2005에서 계층적 데이터를 검색하는 것은 어려울 수 있으며, 특히 자체 참조를 처리할 때 더욱 그렇습니다. 하위 레코드가 상위 ID를 가리키는 테이블입니다. 뷰와 복잡한 쿼리가 일반적으로 사용되지만 우아함과 효율성이 부족한 경우가 많습니다.

한 솔루션은 CTE(공용 테이블 표현식)를 활용하여 계층 구조를 구성하고 각 항목에 대한 경로를 생성합니다. 이 접근 방식에는 루트 노드(ParentID가 NULL임)와 해당 이름을 경로로 선택하는 것으로 시작하는 Parent라는 CTE를 생성하는 작업이 포함됩니다. 그런 다음 하위 노드를 반복적으로 추가하고 해당 이름을 상위 경로에 연결합니다.

다음 코드는 이 접근 방식을 보여줍니다.

CREATE TABLE tblHierarchy (ID int, ParentID int NULL, Name varchar(128));

INSERT INTO tblHierarchy VALUES (1, NULL, '1');
INSERT INTO tblHierarchy VALUES (2, NULL, '2');
INSERT INTO tblHierarchy VALUES (3, NULL, '3');
INSERT INTO tblHierarchy VALUES (4, 1, '1.1');
INSERT INTO tblHierarchy VALUES (5, 1, '1.2');
INSERT INTO tblHierarchy VALUES (6, 4, '1.1.1');

WITH Parent AS
(
    SELECT
        ID,
        ParentID,
        Name AS Path
    FROM
        tblHierarchy
    WHERE
        ParentID IS NULL

    UNION ALL

    SELECT
        TH.ID,
        TH.ParentID,
        CONVERT(varchar(128), Parent.Path + '/' + TH.Name) AS Path
    FROM
        tblHierarchy TH
    INNER JOIN
        Parent
    ON
        Parent.ID = TH.ParentID
)
SELECT * FROM Parent

이 CTE는 다음을 포함하는 추가 열 Path가 있는 계층형 테이블을 생성합니다. 각 노드에 대한 전체 경로. 결과 쿼리 출력은 다음과 같습니다.

ID  ParentID    Path
1   NULL        1
2   NULL        2
3   NULL        3
4   1       1/1.1
5   1       1/1.2
6   4       1/1.1/1.1.1

이 접근 방식은 SQL Server 2005의 자체 참조 테이블에서 계층적 데이터를 검색하는 명확하고 효율적인 방법을 제공합니다. 복잡한 수동 쿼리가 필요하지 않으며 계층 구조 탐색이 더 쉬워졌습니다.

위 내용은 SQL Server 2005의 자체 참조 테이블에서 계층적 데이터를 효율적으로 검색하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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