表内父子关系的递归查询
原理:使用公用表表达式的递归查询
传送门: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
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步