【发布时间】:2013-08-26 07:58:03
【问题描述】:
我有一个运行良好的递归 CTE,但我还需要一件事:在每个结果中添加 [isLeaf] 标志,这将告诉记录是否有更多子项(带有子项计数器的 [Leafs] 字段会更好)。
下面粘贴的工作示例。它计算每个类别的级别并将名称连接到类别路径中,但是 sql server 不允许在 CTE 的递归部分中使用 LEFT JOIN、TOP、SELECT DISTINCT、聚合和子查询,这是我做的显而易见的方法需要。
DROP TABLE cats
GO
create table cats(
catid int primary key clustered,
parent int, --parent's catid. 0 for top-level entries
name varchar(255)
)
GO
insert into cats (catid, parent, name)
select 1 as catid, 0 as parent, 'computers' as name union all
select 2, 1, 'laptops' union all
select 4, 2, 'ibm' union all
select 5, 2, 'others' union all
select 3, 1, 'desktops' union all
select 6, 3, 'amd' union all
select 7, 3, 'others' union all
select 8, 0 , 'cars' union all
select 9, 8, 'others' union all
select 10, 8, 'pickups' union all
select 11, 10, 'others' union all
select 12, 10, 'ford' union all
select 14, 12, 'ranger' union all
select 15, 12, 'others'
GO
;with cteCat as (
select
CatId, Parent,
[cteLevel] = 1,
[ctePath] = cast(Name as varchar(4000))
--,[cteIsLeaf] = 0
from cats
where 1=1
and Parent=0
union all
select
c.CatId, c.Parent,
[cteLevel] = cc.cteLevel+1,
[ctePath] = cast(cc.ctePath + ' | ' + c.Name as varchar(4000))
--,[cteIsLeaf] = 0 --???--
from cats c
join cteCat cc
on c.Parent = cc.CatId
where 1=1
and c.Parent<>0
)
select
*
from cteCat
order by
catid
【问题讨论】:
-
从 Sql Server 2008 开始,有一个特殊的数据类型 hierarchyId 可以用于分层数据。
-
@NikolaMarkovinović 很棒的提示,谢谢!我不知道这种类型的存在,但现在我可以在我的项目中看到它的许多应用程序。
标签: sql tsql recursion sql-server-2008-r2 common-table-expression