재귀 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에서는 무한 레코드 집합을 방지하기 위해 제한을 적용합니다.
자세한 내용은 다음 문서를 참조하세요.
위 내용은 재귀 CTE는 어떻게 단계별로 실행됩니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!