sql递归查询所有子节点_数据库大师成长日记:浅论通过SQL语句实现递归查询

对于经常写各种程序的朋友来说,递归调用是程序绕不开的话题,比如我们要生成一颗拥有层次关系的部门树等。程序中的递归,无非是函数或过程调用自身,根据某种关联关系自动将数据的层级关系梳理出来。但在数据库中,有没有办法直接通过递归把数据梳理出来呢?

1aa9c8696f42d6c462befdbc60c21866.png

我们存入数据库表的数据,比如部门员工数据,很可能放在同一个表中,部门员工的数据又是分层级的,但数据的插入可能是无序的。我们如何通过SQL语句将数据按照层级梳理出来呢?

通过SQL语句实现递归查询,当然也可以通过定义自定义函数使用游标、通过递归调用来实现,考虑到脚本的简洁和效率,这种方式肯定是不合适的。

那如何实现呢?推荐用公用表表达式。下面我们就通过一个表变量存放部门员工数据,通过公用表表达式的递归调用实现部门员工数据的递归查询。

演示数据准备

直接先上脚本:

declare @data table( FDataID int, FParentID int, FName nvarchar(255), FIsNode tinyint);insert into @data values(1,0,'销售一部',1),(2,1,'张三',0),(3,0,'销售二部',1),(4,1,'李四',0),(5,3,'王五',1);

这里定义了一个表变量&

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值