sql >> Databáze >  >> RDS >> Sqlserver

Jak vytvořit SQL Server 2005 CTE pro vrácení záznamů rodič-dítě pro děti s více rodiči

Zdá se, že to pro mě funguje OK, jakmile jsem opravil chybu syntaxe ve vašem CTE:

create table #ParentChildTable 
(nodeID int not null
,parentNodeID int not null
)

insert #ParentChildTable 
select 900,56
union all select 900,123
union all select 123,439
union all select 56,439
union all select 439,0

;WITH Heirarchy
AS
(
    SELECT 
        T1.NodeID,
          T1.ParentNodeID
    FROM
        #ParentChildTable T1
    WHERE
        T1.NodeID = 439

    UNION ALL
    SELECT 
        T1.NodeID,
        T1.ParentNodeID
    FROM
        #ParentChildTable T1
        INNER JOIN Heirarchy TH ON TH.NodeID = T1.ParentNodeID
)
select *
from Heirarchy

Vrátí výsledek:

NodeID      ParentNodeID
----------- ------------
439         0
123         439
56          439
900         56
900         123


  1. Replikace databáze nebo zrcadlení?

  2. Jak mohu přenést int do bitu v MySQL 5.1?

  3. Weird MySQL Python mod_wsgi Nelze se připojit k serveru MySQL na „localhost“ (49) problém

  4. Vrátit řádek s maximální hodnotou jednoho sloupce na skupinu