原理:使用公用表表達式的遞歸查詢 傳送門:https://msdn.microsoft.com/zh-cn/library/ms186243 問題:指定一個父級,查詢出該父級下麵的所有節點。 舉例說明:存在表 ComponentI為子,PP_ComponentID為父。 CREATE PROCEDU...
原理:使用公用表表達式的遞歸查詢
傳送門:https://msdn.microsoft.com/zh-cn/library/ms186243
問題:指定一個父級,查詢出該父級下麵的所有節點。
舉例說明:存在表
ComponentI為子,PP_ComponentID為父。
CREATE PROCEDURE [dbo].[PP1_BOMComponentSelectAll2_SEL] --'01'
@ComponentID VARCHAR(20)
AS
BEGIN
WITH locs(ComponentID,PP__ComponentID,ComponentName,loclevel)
AS
(
SELECT ComponentID,PP__ComponentID,ComponentName, 0 AS loclevel FROM PP_Component WHERE PP__ComponentID=@ComponentID
UNION ALL
SELECT A.ComponentID,A.PP__ComponentID,A.ComponentName,loclevel+1 FROM PP_Component A INNER JOIN locs B ON A.PP__ComponentID = B.ComponentID
)
select ComponentID from locs
END