码迷,mamicode.com
首页 > 数据库 > 详细

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

时间:2018-09-21 18:25:15      阅读:294      评论:0      收藏:0      [点我收藏+]

标签:level   优先   命名   执行   递归   定义   weight   实现   bsp   

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; 

 

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

标签:level   优先   命名   执行   递归   定义   weight   实现   bsp   

原文地址:https://www.cnblogs.com/Fooo/p/9687811.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!