sql >> Database >  >> RDS >> Sqlserver

Records ophalen met alle onderliggende records op de sql-server

U moet een recursieve algemene tabelexpressie gebruiken en vervolgens de resultaten filteren voor alleen het basispad voor elk record (d.w.z. voor ID 1131:haal ABC/RST/UVW en niet alleen ABC/RST

WITH CTE AS
(   SELECT  ID, 
            Name, 
            ParentID, 
            NextParentID = ParentID, 
            Path = CAST(Name AS VARCHAR(MAX)),
            Recursion = 1
    FROM    T
    UNION ALL
    SELECT  CTE.ID, 
            CTE.Name, 
            CTE.ParentID, 
            T.ParentID, 
            CAST(T.Name + '/' + CTE.Path AS VARCHAR(MAX)),
            Recursion + 1
    FROM    CTE
            INNER JOIN T
                ON CTE.NextParentID = T.ID
), CTE2 AS
(   SELECT  CTE.ID,
            CTE.Name,
            CTE.ParentID,
            CTE.Path,
            RowNumber = ROW_NUMBER() OVER(PARTITION BY CTE.ID ORDER BY Recursion DESC)
    FROM    CTE
)
SELECT  ID, Name, ParentID, Path
FROM    CTE2
WHERE   RowNumber = 1;

Voorbeeld op SQL Fiddle



  1. SQL / MySQL - Sorteren op lengte van kolom

  2. hoe je twee tabellen samenvoegt om de laatste nieuwe rijen uit tabel 2 te krijgen en de rest uit tabel 1

  3. PHPpgAdmin:rijen verwijderen zonder SQL te gebruiken

  4. PostgreSQL:tijd voor het maken van tabellen