SQLServer -- 递归查询树结构表

 

需求


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

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

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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值