Sqlserver
 sql >> Baza danych >  >> RDS >> Sqlserver

Rekurencyjne łączenie elementów nadrzędnych

Możesz użyć rekurencyjnego CTE .

declare @T table(ID int, Name char(1), Parent int);

insert into @T values  
(1      ,'A'       ,NULL),
(2      ,'B'       ,NULL),
(3      ,'C'       ,1),
(4      ,'D'       ,1),
(5      ,'E'       ,3),
(6      ,'F'       ,5);

with C as
(
  select ID,
         Name,
         Parent,
         cast('' as varchar(max)) as ParentNames
  from @T
  where parent is null
  union all
  select T.ID,
         T.Name,
         T.Parent,
         C.ParentNames + ' > ' + C.Name
  from @T as T         
    inner join C
      on C.ID = T.Parent
)      
select ID,
       Name,
       stuff(ParentNames, 1, 3, '') as ParentNames
from C;     


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Uzyskiwanie i instalacja Microsoft SQL Server Management Studio

  2. Kursor SQL Server - pętla przez wiele serwerów i wykonanie zapytania

  3. Jak ustawić zmienną z zapytania SQL?

  4. Jak dowiedzieć się, co blokuje moje stoły?

  5. Jak mogę wykonać kopię zapasową zdalnej bazy danych SQL Server na dysku lokalnym?