SqlServer 递归查询树形数据


转自:http://www.cnblogs.com/Lixinhua-GoOn/archive/2016/01/29/5169297.html

SqlServer 递归查询树形数据

一直没有在意过数据库处理树形数据的重要性,直到有一天朋友问起我关于树形数据查询的问题时才发现根本不会,正好这个时候也要用到递归进行树形数据的查询于是在网上查了一圈,语法总结如下

参考文献:https://msdn.microsoft.com/query/dev10.query?appId=Dev10IDEF1&l=ZH-CN&k=k(WITH_TSQL);k(SQL11.SWB.TSQLRESULTS.F1);k(SQL11.SWB.TSQLQUERY.F1);k(MISCELLANEOUSFILESPROJECT);k(DevLang-TSQL)&rd=true

 

一:简单的树形数据 代码如下:

复制代码
-- with一个临时表(括号中是你要查询的列名)
with temp(ID,PID,Name,curLevel)
as
(
--1初始查询(这里的PID=-1 在我的数据中是最底层的根节点)
select ID,PID,Name,1 as level from dbo.T_ACL_OU 
where Deleted = 0 and PID = -1     
union all
--2递归条件
select a.ID,a.PID,a.Name, b.curLevel+1from T_ACL_OU a   --3这里的临时表和原始数据表都必须使用别名,不然递归的时候不知道查询的是那个表的列
inner join
temp b
on ( a.PID=b.id)  --这个关联关系很重要,一定要理解一下谁是谁的父节点
)
select * from temp   --4递归完成后 一定不要少了这句查询语句 否则会报错
复制代码

效果如图:


这里要注意的地方是注释中的 1——4 的部分

二:带缩进的树形数据 代码如下:

复制代码
with temp(ID,PID,Name,curLevel)
as
(
--初始查询
select ID,PID,Name,1 as curLevel from dbo.T_ACL_OU 
where Deleted = 0 and PID = -1     
union all
--递归条件
select a.ID,a.PID, convert(nvarchar(100),CONVERT(nvarchar(100), REPLICATE ('    ', b.curLevel+1)+a.Name)) as Name , b.curLevel+1   --这里的 REPLICATE函数非常重要,用于缩进空格用。不懂得可以在SQLserver中选中后按F1键
from T_ACL_OU a 
inner join
temp b
on ( a.PID=b.id)
)
select ID,PID,Name,curLevel from temp
复制代码

效果如图:

三:查询是否有子节点

复制代码
with temp(ID,PID,HandNo,Name,curLevel,pLevel,haveChild)
as
(
--初始查询
select ID,PID,HandNo,Name,1 as level,0 as pLevel,1 as haveChild from dbo.T_ACL_OU 
where Deleted = 0 and PID = -1     
union all
--递归条件
select a.ID,a.PID,a.HandNo,a.Name, b.curLevel+1,b.curLevel,haveChild = (case when exists(select 1 from T_ACL_OU where T_ACL_OU.PID=a.id) then 1 else 0 end)--(select 1 from T_ACL_OU where exists(select 1 from T_ACL_OU where a.PID=b.id)) 
from T_ACL_OU a 
inner join
temp b
on ( a.PID=b.id)
)
select * from temp order by pLevel
复制代码

效果如图:

这3段代码可以直接复制使用,修改一下表名和要查询的列名基本上都是通用的,写的比较简单,如果大家有什么意见建议请留言交流谢谢。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQL Server递归查询是一种在关系型数据库中使用递归算法进行数据查询的方法。它可以用于处理具有层次结构的数据,例如组织结构、树形结构等。在SQL Server中,递归查询可以通过使用公共表表达式(CTE)和递归联接来实现。 递归查询的基本思想是通过递归联接将一个表与自身连接,从而实现对层次结构数据的遍历和查询。在递归查询中,需要定义一个递归部分和一个终止条件。 下面是一个示例,演示如何使用递归查询SQL Server中查询组织结构的层级关系: ```sql -- 创建一个示例表 CREATE TABLE Organization ( ID INT, Name VARCHAR(50), ParentID INT ); -- 插入示例数据 INSERT INTO Organization (ID, Name, ParentID) VALUES (1, '公司', NULL), (2, '部门A', 1), (3, '部门B', 1), (4, '小组A1', 2), (5, '小组A2', 2), (6, '小组B1', 3); -- 使用递归查询获取组织结构的层级关系 WITH RecursiveCTE AS ( SELECT ID, Name, ParentID, 0 AS Level FROM Organization WHERE ParentID IS NULL UNION ALL SELECT o.ID, o.Name, o.ParentID, Level + 1 FROM Organization o INNER JOIN RecursiveCTE r ON o.ParentID = r.ID ) SELECT ID, Name, Level FROM RecursiveCTE ORDER BY Level, ID; ``` 上述示例中,我们首先创建了一个名为Organization的表,用于存储组织结构数据。然后插入了一些示例数据。接下来,使用递归查询通过递归联接获取组织结构的层级关系。在递归查询中,我们使用了一个公共表表达式(CTE)来定义递归部分和终止条件。最后,通过查询RecursiveCTE表获取结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值