sql >> Databasteknik >  >> RDS >> Sqlserver

Hämta poster som innehåller alla underordnade poster i sql-servern

Du måste använda ett rekursivt gemensamt tabelluttryck och sedan filtrera resultaten för endast bassökvägen för varje post, (dvs. för ID 1131 hämta ABC/RST/UVW och inte bara 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;

Exempel på SQL Fiddle



  1. Hur man flyttar sedan radera fält i MySQL

  2. hämtar db:SQLSTATE[HY000] [2002] Anslutningsvägrade fel på Mac med MAMP

  3. Hur gör jag många SQL-frågor som transaktioner?

  4. MySQL unicode bokstaver