主页 > 知识库 > SQL SERVER 2008 CTE生成结点的FullPath

SQL SERVER 2008 CTE生成结点的FullPath

热门标签:海南自动外呼系统价格 九鹿林外呼系统怎么收费 浙江地图标注 沧州营销外呼系统软件 电销机器人虚拟号码 创业电销机器人 舞钢市地图标注app 松原导航地图标注 沈阳智能外呼系统代理
好的,现在来看如何生成FullPath:
复制代码 代码如下:

DECLARE @tbl TABLE
(
Id int
,ParentId int
)
INSERT INTO @tbl
( Id, ParentId )
VALUES ( 0, NULL )
, ( 8, 0 )
, ( 12, 8 )
, ( 16, 12 )
, ( 17, 16 )
, ( 18, 17 )
, ( 19, 17 )

WITH abcd
AS (
-- anchor
SELECT id
,ParentID
,CAST(id AS VARCHAR(100)) AS [Path]
FROM @tbl
WHERE ParentId IS NULL
UNION ALL
--recursive member
SELECT t.id
,t.ParentID
,CAST(a.[Path] + ',' + CAST( t.ID AS VARCHAR(100)) AS varchar(100)) AS [Path]
FROM @tbl AS t
JOIN abcd AS a ON t.ParentId = a.id
)
SELECT Id ,ParentID ,[Path]
FROM abcd
WHERE Id NOT IN ( SELECT ParentId
FROM @tbl
WHERE ParentId IS NOT NULL )

返回:
Id ParentID Path
----------- ----------- ----------------------
18 17 0,8,12,16,17,18
19 17 0,8,12,16,17,19
就这么简单,实际上有Sql server 2008中HierarchyType 也能很好的解决这个问题。我将在后面写一些关于HierarchyType的Post.

希望这篇POST对您有帮助。

Author Peter Liu

标签:商洛 宝鸡 日喀则 台湾 西藏 咸宁 海口 公主岭

巨人网络通讯声明:本文标题《SQL SERVER 2008 CTE生成结点的FullPath》,本文关键词  SQL,SERVER,2008,CTE,生成,结点,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《SQL SERVER 2008 CTE生成结点的FullPath》相关的同类信息!
  • 本页收集关于SQL SERVER 2008 CTE生成结点的FullPath的相关信息资讯供网民参考!
  • 推荐文章