The*_*ght 4 t-sql sql-server hierarchy while-loop
我有以下存储过程来返回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
Run Code Online (Sandbox Code Playgroud)
"NiceUrls"表有Id和ParentId.parentId引用同一个表中的记录.
它返回如下:
----------------------------------
Id | ParentId | AbsoluteUrl
----------------------------------
294 | 5 | url1
5 | 2 | url2
2 | 0 | url3
Run Code Online (Sandbox Code Playgroud)
上面的代码使用WHILE循环和定义一个Table变量工作正常,但我只是想知道有没有更好的方法从表中检索层次结构数据?
上述代码的问题是可维护性.如果我需要再返回NiceUrls表的另一列,那么我必须定义一个新变量,将列添加到内联表中,等等.
有没有更好的方法来重写sp?
谢谢,
什么是
The*_*ght 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
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
10744 次 |
| 最近记录: |