码迷,mamicode.com
首页 > 其他好文 > 详细

表内父子关系的递归查询

时间:2016-01-04 19:54:07      阅读:198      评论:0      收藏:0      [点我收藏+]

标签:

原理:使用公用表表达式的递归查询

传送门: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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!