T-SQL使用CTE递归

Posted 高手皆寂寞-->何时才能寂寞呢?

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了T-SQL使用CTE递归相关的知识,希望对你有一定的参考价值。

DECLARE @DiGui TABLE ( Id INT, ParentId INT )
INSERT  INTO @DiGui
        ( Id ,
          ParentId 
        )
        SELECT  1 ,
                2
        UNION
        SELECT  2 ,
                3
        UNION
        SELECT  3 ,
                4
        UNION
        SELECT  5 ,
                10
        UNION
        SELECT  1 ,
                10
SELECT  *
FROM    @DiGui ;
WITH    temp ( [Id], [parentid] )
          AS ( SELECT   Id ,
                        parentid
               FROM     @DiGui
               WHERE    [Id] = 1
               UNION ALL
               SELECT   a.Id ,
                        a.parentid
               FROM     @DiGui a
                        INNER JOIN temp ON a.[Id] = temp.[parentid]
             )
    SELECT  *
    FROM    temp

  结果:

 

以上是关于T-SQL使用CTE递归的主要内容,如果未能解决你的问题,请参考以下文章

T-SQL 公用表表达式(CTE)

T-SQL 之 公用表表达式(CTE)

具有 CTE 的 T-SQL 窗口函数,使用先前计算的值

T-SQL:CTE用法

SQL Server CTE 递归查询全解

通过递归 CTE 分解 BOM