Вставить новый столбец с информацией предыдущих строк

У меня есть эта таблица:

   Id  |Name        |ParentId 
    1  |John        |Null     
    2  |Oscar       |1        
    3  |Peter       |2        
    4  |Abbey       |3        
    5  |Adrian      |4        
    6  |Barbara     |5    

и я хочу сделать выбор, который даст мне новый столбец, который получает предыдущее имя с помощью parentId для создания listName (Order by ParentID).

окончательный результат в этом примере будет следующим:

   Id  |Name        |ParentId     | List
    1  |John        |Null         | John
    2  |Oscar       |1            | John-Oscar
    3  |Peter       |2            | John-Oscar-Peter
    4  |Abbey       |3            | John-Oscar-Peter-Abbey
    5  |Adrian      |4            | John-Oscar-Peter-Abbey-Adrian
    6  |Barbara     |5            | John-Oscar-Peter-Abbey-Adrian-Barbara

Спасибо за помощь!

2 ответа

Решение

Вы можете использовать рекурсивный CTE для получения желаемого результата:

declare @t table (Id int, Name varchar(20), ParentId int)
insert @t values
(    1  ,'John'        ,Null     ),
(    2  ,'Oscar'       ,1        ),
(    3  ,'Peter'       ,2        ),
(    4  ,'Abbey'       ,3        ),
(    5  ,'Adrian'      ,4        ),
(    6  ,'Barbara'     ,5    )

;with x as (
    select *, cast(name as varchar(1000)) as list from @t where parentid is null
    union all
    select t.id, t.name, t.parentid, cast(x.list+'-'+t.name as varchar(1000)) from @t t join x on t.parentid = x.id
)
select * from x

Это также работает для нескольких корней, конечно.

Это то же самое, что объединить столбцы в строки

select id,name,pid,
stuff((select '-'+name from yourtable  n2 where n2.id<=n1.id for xml path('')),1,1,'') b
from yourtable n1
Другие вопросы по тегам