明天的明天 永远的永远 未知的一切 我与你一起承担 ??

是非成败转头空 青山依旧在 几度夕阳红 。。。
随笔 - 1277, 文章 - 0, 评论 - 214, 阅读 - 320万
  博客园  :: 首页  :: 管理
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

SqlServer :实现树形结构递归查询(无限极分类)

Posted on   且行且思  阅读(5032)  评论(0编辑  收藏  举报

SQL Server 2005开始,我们可以直接通过CTE来支持递归查询,CTE即公用表表达式 公用表表达式(CTE),是一个在查询中定义的临时命名结果集将在from子句中使用它。每个CTE仅被定义一次(但在其作用域内可以被引用任意次),并且在该查询生存期间将一直生存。可以使用CTE来执行递归操作。

 

一、查询树状结构某节点下的所有子节点

复制代码
with cte_child(id,areaName,pid,level)
as
(
    --起始条件
    select id,areaName,pid,0 as level from erp_area
    where id = 1 -- 优先列出第一节点查询条件
 
    union all
 
    --递归条件 
    select a.id,a.areaName,a.pid,b.level+1 
    from erp_area a 
    inner join  
    cte_child b 
    on ( a.pid=b.id)  
)
select  * from cte_child 
复制代码

 

二、查询树状结构某节点(44)的上级所有根节点

复制代码
with cte_child(id,areaName,pid) 
as 
(
 
    --起始条件 
    select id,areaName,pid from erp_area 
    where id = 44   --列出子节点查询条件
 
    union all
 
    --递归条件
 
    select a.id,a.areaName,a.pid 
    from erp_area a 
    inner join  
    cte_child b          --执行递归 
    on a.id=b.pid   
)       
select * from cte_child; 
复制代码

 

编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
点击右上角即可分享
微信分享提示