本文介紹了遞歸 t-sql 查詢的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!
問題描述
我有一張如下所示的表格.
I have a table as shown below.
ID ParentID Node Name Node Type
------------------------------------------------------------------
525 524 Root Area Level 1
526 525 C Area Level 2
527 525 A Area Level 2
528 525 D Area Level 2
671 525 E Area Level 2
660 527 B Area Level 3
672 671 F Area Level 3
如何編寫遞歸 t-sql 查詢以生成以下輸出?
How can i write a recursive t-sql query to generate below output?
輸出(輸出中不需要根"節點):
Output ("Root" node not required in the output):
Node ID
-----------------------
A 527
A/B 660
C 526
D 528
E 671
E/F 672
謝謝
推薦答案
查看 本頁 使用公共表表達式.這就是我會使用的(假設您至少使用 SQL Server 2005)
Take a look at this page on using common table expressions. That is what I would use (assuming you are using at least SQL Server 2005)
這是使用您的案例的代碼示例:
Here is a code example using your case:
WITH CTE (NodePath, ID) AS (
SELECT
'/' + CAST(NodeName AS NVARCHAR(MAX)) AS NodePath,
ID
FROM TABLE
WHERE NodeName = 'Root'
UNION ALL
SELECT
CTE.NodePath + '/' + CAST(NodeName AS NVARCHAR(MAX)) AS NodePath,
TABLE.ID
FROM CTE
INNER JOIN TABLE ON TABLE.ParentId = CTE.ID
)
SELECT
NodeName,
ID
FROM CTE
這篇關于遞歸 t-sql 查詢的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持html5模板網!
【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!