繁体   English   中英

T-SQL中的递归聚合

[英]Recursive Aggregate in T-SQL

我正在使用的架构的简化版本如下所示:

节点:

Id Name   ParentId
0  Parent NULL
1  Child1 0
2  Child2 0

属性:

Id NodeId Value
0  1      1
1  1      2

因此,一个节点可以有多个作为子节点,而一个节点也可以具有许多属性。

我想创建一个视图,将节点的ID映射到其所有属性及其所有子级属性的MAX值。 因此,对于上面的示例数据,该视图应包含:

Id Value
0  2
1  2
2  NULL

我曾与CTE尝试过各种方法,但无法使其正常工作。 有任何想法吗?

试试看:

;with nodeAttributes as (
    select n.Id, n.Name, n.ParentId, a.Value
    from Nodes n
    left outer join Attributes a on n.Id = a.NodeId
),
cte as
(
    select n.Id, n.Name, n.Id RootId, n.ParentId, n.Value
    from nodeAttributes n

    union all

    select n.Id, n.Name, c.RootId, n.ParentId, n.Value
    from nodeAttributes n
    join cte c on c.Id = n.ParentId
)

select n.Id,  x.maxValue
from Nodes n
join (select RootId, max(Value) maxValue
      from cte
      group by RootId) x on x.RootId = n.Id

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM