sql >> Databáze >  >> RDS >> Sqlserver

t-sql rekurzivní dotaz

Zde je příklad CTE, jak to udělat:

declare @t table (id int, name varchar(max), parentid int)

insert into @t select 1,     'project'  , 0
union all select 2,     'structure' , 1
union all select 3,     'path_1'    , 2
union all select 4,     'path_2'    , 2
union all select 5,     'path_3'    , 2
union all select 6,     'path_4'    , 3
union all select 7,     'path_5'    , 4
union all select 8,     'path_6'    , 5

; with CteAlias as (
    select id, name, parentid
    from @t t
    where t.parentid = 0
    union all
    select t.id, parent.name + '\' + t.name, t.parentid
    from @t t
    inner join CteAlias parent on t.parentid = parent.id
)
select * 
from CteAlias


  1. OracleSQL převádí pole Datum do jiného časového pásma

  2. Jak mohu zobrazit, zda letecká společnost odlétá ze všech letišť v mé DB v Postgresql?

  3. Vyberte z jedné tabulky, kde v jiné ne

  4. jedinečný index mysql používaný jako metoda zpracování výjimek v jazyce Java