标签:
原理:使用公用表表达式的递归查询
传送门: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
?
?
?
标签:
原文地址:http://www.cnblogs.com/chunlai99/p/5099905.html