sql >> Database teknologi >  >> RDS >> Sqlserver

Hent poster, der indeholder alle underordnede poster i sql server

Du skal bruge et rekursivt fælles tabeludtryk og derefter filtrere resultaterne for kun basisstien for hver post, (dvs. for ID 1131 få ABC/RST/UVW og ikke kun 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;

Eksempel på SQL Fiddle



  1. Brug af PATINDEX til at finde mønstre med varierende længde i T-SQL

  2. sql-meddelelsestabelforespørgsel

  3. Prøvestørrelse og varigheden af ​​OPDATERINGSSTATISTIK:Betyder det noget?

  4. Postgresql date_trunc med tidszone skifter zone med 1 time