SQLServer -- 递归查询树结构表

本文介绍了一种使用CTE(Common Table Expression)递归查询树形结构表中任意节点及其所有子节点的方法,并通过具体实例展示了如何实现这一查询。

 

需求


查询树结构表(如菜单类型表,文件夹类型表等)中一个数据节点下所有的子节点数据

声明临时表,并写入数据如下

DECLARE @tbl TABLE 
(
     Id INT
     ,ParentId INT
     ,Name VARCHAR(50)
)

INSERT INTO @tbl( Id, Name, ParentId )
    VALUES
     (1, '文件夹1', NULL)
    ,(2, '文件夹2',   NULL)
    ,(3, '文件夹1-1', 1)
    ,(4, '文件夹1-2', 1)
    ,(5, '文件夹1-1-1',3)
    ,(6, '文件夹1-1-2',3)
    ,(7, '文件夹1-2-1', 4)
    ,(8, '文件夹2-1', 2)
    ,(9, '文件夹2-1-1',8)

 

查询需求:查询出任一文件夹及其它所包含的子文件夹。

 

 

查询方案


1. 利用CTE方式查询

;WITH  CTE
AS 
(
    SELECT  ID, [Name], ParentID
    FROM @tbl
    WHERE Id=1 --文件ID
    UNION ALL
    SELECT t.ID, t.[Name], t.ParentID
    FROM @tbl AS t
    JOIN CTE AS a ON t.ParentId = a.ID --这里条件不能写成 t.ID=a.ParentId,否则无法完成递归
)
SELECT * FROM CTE

 

转载于:https://www.cnblogs.com/alan_peng/p/5945901.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值