sql >> Database >  >> RDS >> Sqlserver

SQL-query voor bovenliggende-onderliggende keten

Gebruik een recursieve CTE :

DECLARE @id INT
    SET @id = 3

;WITH hierarchy AS (
  SELECT t.id, t.parentid
    FROM YOUR_TABLE t
   WHERE t.id = @id
 UNION ALL
 SELECT x.id, x.parentid
   FROM YOUR_TABLE x
   JOIN hierarchy h ON h.parentid = x.id)
SELECT h.id
  FROM hierarchy h

Resultaten:

id
---
3
2
1


  1. MYSQL:JOIN maakt SUM dubbel

  2. SMALLDATETIMEFROMPARTS() Voorbeelden in SQL Server (T-SQL)

  3. Hoe detecteer je dat de transactie al is gestart?

  4. Kan Oracle Data Provider voor .NET niet zien in Visual Studio 2012 RC