SQL 语句递归查询 With AS 查找所有子节点
create table #EnterPrise
(
  Department nvarchar(50),--部门名称
  ParentDept nvarchar(50),--上级部门
  DepartManage nvarchar(30)--部门经理
)
insert into #EnterPrise select '技术部','总经办','Tom'
insert into #EnterPrise select '商务部','总经办','Jeffry'
insert into #EnterPrise select '商务一部','商务部','ViVi'
insert into #EnterPrise select '商务二部','商务部','Peter'
insert into #EnterPrise select '程序组','技术部','GiGi'
insert into #EnterPrise select '设计组','技术部','yoyo'
insert into #EnterPrise select '专项组','程序组','Yue'
insert into #EnterPrise select '总经办','','Boss'
--查询部门经理是Tom的下面的部门名称
;with hgo as
(
   select *,0 as rank from #EnterPrise where DepartManage='Tom'
   union all
   select h.*,h1.rank+1 from #EnterPrise h join hgo h1 on h.ParentDept=h1.Department
)
select * from hgo
/*
Department          
ParentDept               
DepartManage      rank
--------------- -------------------- ----------------------- -----------
技术部              
总经办                   
Tom              
0
程序组              
技术部                   
GiGi             
1
设计组              
技术部                   
yoyo             
1
专项组              
程序组                   
Yue              
2
*/
--查询部门经理是GiGi的上级部门名称
;with hgo as
(
   select *,0 as rank from #EnterPrise where DepartManage='GiGi'
   union all
   select h.*,h1.rank+1 from #EnterPrise h join hgo h1 on h.Department=h1.ParentDept
)
select * from hgo
/*
Department              
ParentDept         
DepartManage    rank
-------------------- ----------------------  -----------  -----------
程序组                  
技术部                
GiGi           0
技术部                  
总经办                
Tom            1
总经办                                         
Boss           2
*/
如果递归次数大于100,只需在与cte连接的sql 语句的最后加上option (maxrecursion 0) 即可.默认递归
次数为100,设为0表示没有次数限制.
SQL 语句递归查询 With AS 查找所有子节点的更多相关文章
- sql语句递归查询(start with)
		在做项目中遇到一个问题,就是同一个表中的数据存在级联关系,但是只要查出来的末级数据,纠结了好久,好不容易找到了一个博主的分享,在这里做个记录,也是和大家一起分享学习一下这位大神的技术,共勉 写代码时碰 ... 
- mysql  递归查找所有子节点
		select dept_id from ( select t1.dept_id,t1.parent_id, if(find_in_set(parent_id, @pids) > 0, @pids ... 
- [SQL]T-Sql 递归查询(给定节点查所有父节点、所有子节点的方法)
		T-Sql 递归查询(给定节点查所有父节点.所有子节点的方法) -- 查找所有父节点with tab as( select Type_Id,ParentId,Type_Name from Sys_ ... 
- SQL 递归查询(根据指定的节点向上获取所有父节点,向下获取所有子节点)
		--------------------01.向上查找所有父节点-----------------WITH TEMP AS (SELECT * FROM CO_Department WHERE ID= ... 
- sql语句错误
		此错误一般有以下情况造成: 1.配置文件中SQL语句写的有问题 2.传参过程中没有找到sql对应的参数 解决方法: 1.检查sql语句 2.debug启动,查找与sql语句相对应的参数是否存在. 3. ... 
- log4j向oracle中插入一条系统当前时间的sql语句
		配置log4j,要向oracle插入一条系统当前时间的sql语句,按网上查找的总是出现各种各样的报错,最后总结出的写法是: ### shezhi### log4j.rootLogger = debug ... 
- EF 记录执行的sql语句
		最近做了个中等的项目,数据不会很多,开发时间比较紧迫,所以用了EF的框架. 在使用过程中,发现有时候执行的结果不如预期,想看看执行的sql语句为何,遍查找资料,在网上找到了相关辅助类,拿来使用,部署到 ... 
- T-Sql 递归查询(给定节点查所有父节点、所有子节点的方法)
		-- 查找所有父节点with tab as( select Type_Id,ParentId,Type_Name from Sys_ParamType_V2_0 where Type_Id=316-- ... 
- MySql 利用函数 查询所有子节点
		前提:mysql 函数 find_in_set(str,strlist), cast(value as type) 一.find_in_set(str,strlist):如果字符串str是在的 ... 
随机推荐
- 为什么谷歌的JSON响应以while(1);开头?
			问题(QUESTION): 我有个问题一直很好奇就是:为什么谷歌的JSON响应以while(1);开头?举个例子,当把谷歌日历打开和关掉时,会返回这样的JSON对象: while(1);[['u',[ ... 
- ASP.NET MVC 编程参考
			ASP.NET MVC 编程参考 转载请注明出处:http://surfsky.cnblogs.com MVC 参考 http://msdn.microsoft.com/zh-cn/dd40 ... 
- Android -- 获取IP和MAC地址
			通过InetAddress.getLocalHost()得到始终是“127.0.0.1”,要想得到真正的网络ip地址要通过下面的方法: 首先新建一个工程,修改AndroidManifest.xml文件 ... 
- 老三星手机i9001刷机记录
			家里的老的三星i9001,准备给我妈用,打算刷机,但又实在头疼那些复杂的刷机技术,昨天研究了一下,用比较简单的方法完成刷机,记录如下: 用卡刷比较简单,线刷不考虑 进入恢复模式的方法:1.电源+音量加 ... 
- js 切换隐藏
			先试试 显示\隐藏切换 脚本之家欢迎您 切换隐藏 <style type="text/css"> #thediv { width:200px; height:100px ... 
- easyui tree带checkbox实现单选
			<ul id="regionTree"></ul> $('#regionTree').tree({ cascadeCheck: false, //onlyL ... 
- Java8新特性 - Lambda表达式 - 基本知识
			A lambda expression is an unnamed block of code (or an unnamed function) with a list of formal param ... 
- ADS中编译现存项目时常见错误:无法打开文件\…\…\2440init.o的解决办法
			错误提示如下: 解决方法: 重新编译即可. 
- 算法笔记_118:算法集训之结果填空题集二(Java)
			目录 1 欧拉与鸡蛋 2 巧排扑克牌 3 排座位 4 黄金队列 5 汉诺塔计数 6 猜生日 7 棋盘上的麦子 8 国庆星期日 9 找素数 10 填写算式 11 取字母组成串 1 欧拉与鸡蛋 大数 ... 
- MySQL双主如何解决主键冲突问题
			搭建了个双主,突然想到如果表设置了自增主键的话,当业务同时向双库中插入一条数据,这时候情况是什么样子的呢? 比如:主库A和主库B上的一个表数据为: 12 'ninhao' .当业务同时写入数据后主库A ... 
