>데이터 베이스 >MySQL 튜토리얼 >재귀 CTE는 어떻게 단계별로 실행됩니까?

재귀 CTE는 어떻게 단계별로 실행됩니까?

Patricia Arquette
Patricia Arquette원래의
2025-01-01 09:31:09351검색

How Does a Recursive CTE Execute Step-by-Step?

재귀 CTE는 한 줄씩 어떻게 실행되나요?

무한 UNION ALL과 같은 재귀 CTE는 기본 사례와 여러 재귀 호출. 다음을 고려하십시오.

WITH    rows AS
        (
        SELECT  *
        FROM    mytable
        WHERE   anchor_condition
        ),
        rows2 AS
        (
        SELECT  *
        FROM    set_operation(mytable, rows)
        ),
        rows3 AS
        (
        SELECT  *
        FROM    set_operation(mytable, rows2)
        ),
        …
SELECT  *
FROM    rows
UNION ALL
SELECT  *
FROM    rows2
UNION ALL
SELECT  *
FROM    rows3
UNION ALL
…

제공된 예에서:

WITH    abcd1 AS
        ( 
        SELECT  *
        FROM    @tbl t
        WHERE   ParentId IS NULL 
        ),
        abcd2 AS
        ( 
        SELECT  t.*
        FROM    abcd1
        JOIN    @tbl t
        ON      t.ParentID = abcd1.id
        ),
        abcd3 AS
        ( 
        SELECT  t.*
        FROM    abcd2
        JOIN    @tbl t
        ON      t.ParentID = abcd2.id
        ),
        abcd4 AS
        ( 
        SELECT  t.*
        FROM    abcd3
        JOIN    @tbl t
        ON      t.ParentID = abcd3.id
        ),
        abcd5 AS
        ( 
        SELECT  t.*
        FROM    abcd4
        JOIN    @tbl t
        ON      t.ParentID = abcd4.id
        ),
        abcd6 AS
        ( 
        SELECT  t.*
        FROM    abcd5
        JOIN    @tbl t
        ON      t.ParentID = abcd5.id
        )
SELECT  *
FROM    abcd1
UNION ALL
SELECT  *
FROM    abcd2
UNION ALL
SELECT  *
FROM    abcd3
UNION ALL
SELECT  *
FROM    abcd4
UNION ALL
SELECT  *
FROM    abcd5
UNION ALL
SELECT  *
FROM    abcd6

각 앵커 반복은 새로운 재귀 호출을 생성하여 중첩된 레이어 세트를 생성합니다. 앵커는 한 번 호출되어 시작점 역할을 합니다. 후속 반복에서는 이전 호출의 결과를 사용하여 재귀 멤버를 채웁니다.

abcd6은 결과를 반환하지 않으므로 중지 조건을 의미합니다. 이론적으로 재귀 CTE는 무한할 수 있지만 SQL Server에서는 무한 레코드 집합을 방지하기 위해 제한을 적용합니다.

자세한 내용은 다음 문서를 참조하세요.

  • [SQL Server: 재귀적입니다. CTE는 정말 집합 기반?](https://www.sqlshack.com/sql-server-recursive-ctes-really-set-based/)

위 내용은 재귀 CTE는 어떻게 단계별로 실행됩니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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