我有以下存储过程返回Id,parentId和absoluteUrls列表,工作正常:
ALTER PROCEDURE [dbo].[SearchDataManager.HierarchyById]
@currentId AS int
AS
BEGIN
DECLARE @id INT
DECLARE @parentId INT
DECLARE @absoluteUrl NVARCHAR(1000)
DECLARE @Hierarchy TABLE (Id int, ParentId int, AbsoluteUrl nvarchar(1000))
WHILE @currentId != 0
BEGIN
SELECT @id = Id, @parentId = ParentId, @absoluteUrl = AbsoluteUrl
FROM dbo.[SearchDataManager.NiceUrls]
WHERE id = @currentId
INSERT INTO @Hierarchy VALUES (@id, @parentId, @absoluteUrl)
SET @currentId = @parentId
END
SELECT * FROM @Hierarchy
END
“NiceUrls”表有Id和ParentId。 parentId引用同一个表中的记录。
它返回如下:
----------------------------------
Id | ParentId | AbsoluteUrl
----------------------------------
294 | 5 | url1
5 | 2 | url2
2 | 0 | url3
上面的代码使用WHILE循环并定义了一个Table变量,但我只是想知道有没有更好的方法从表中检索层次结构数据?
上述代码的问题是可维护性。如果我需要返回NiceUrls表的另一列,那么我必须定义一个新变量,将列添加到内联表中等。
有没有更好的方法来重写sp?
谢谢,
什么是
答案 0 :(得分:19)
with Hierarchy (Id, ParentId, AbsoluteUrl, Level)
AS
(
-- anchor member
SELECT Id,
ParentId,
AbsoluteUrl,
0 AS Level
FROM dbo.[NiceUrls]
WHERE id = @currentId
UNION ALL
-- recursive members
SELECT su.Id,
su.ParentId,
su.AbsoluteUrl,
Level + 1 AS Level
FROM dbo.[NiceUrls] AS su
INNER JOIN Hierarchy ON Hierarchy.ParentId = su.Id
)
SELECT * FROM Hierarchy
答案 1 :(得分:2)
您希望源表中的所有记录都与原始ID相关。
1)创建一个CTE,为您提供所有ID(请参阅三重注释链接)
2)将此CTE加入原始表