1,原始查询

原始表格查询:

   select * from dbo.T_DeptInfo;

原始表格查询结果:

2,递归查询

-- with 一个临时表(括号里包括的是你要查询的列名)
with tem_table(dept_id,parent_id,dep_name,curlevel)
as
(
--1,初始查询(这里的parent_id='000'是我门数据中最底层的根节点)
select dept_id, parent_dept_id, dept_name, 1 as level
from
dbo.T_DeptInfo
where
parent_dept_id = '000'
union all
--2,递归条件
select a.dept_id, a.parent_dept_id, a.dept_name, b.curlevel+1
from
dbo.T_DeptInfo a
inner join
tem_table b
on (a.parent_dept_id = b.dept_id)
)
select * from tem_table; --3,递归完成后,一定不能少了这句查询语句,否则会报错

递归查询结果

3,带缩进的的树形递归查询

-- with 一个临时表(括号里包括的是你要查询的列名)
with tem_table(dept_id,parent_id,dep_name,curlevel)
as
(
--1,初始查询(这里的parent_id='000'是我门数据中最底层的根节点)
select dept_id, parent_dept_id, dept_name, 1 as level
from
dbo.T_DeptInfo
where
parent_dept_id = '000'
union all
--2,递归条件
select a.dept_id, a.parent_dept_id,
convert(varchar(100),convert(varchar(100),replicate(' ',b.curlevel+1) + a.dept_name )) as dept_name ,
b.curlevel+1
from
dbo.T_DeptInfo a
inner join
tem_table b
on (a.parent_dept_id = b.dept_id)
)
select * from tem_table; --3,递归完成后,一定不能少了这句查询语句,否则会报错

缩进递归查询结果

4,查询是否子节点的树形递归查询

-- with 一个临时表(括号里包括的是你要查询的列名)
with tem_table(dept_id,parent_id,dep_name,curlevel,havechild)
as
(
--1,初始查询(这里的parent_id='000'是我门数据中最底层的根节点)
select dept_id, parent_dept_id, dept_name, 1 as level,1 as havechild
from
dbo.T_DeptInfo
where
parent_dept_id = '000'
union all
--2,递归条件
select a.dept_id, a.parent_dept_id, a.dept_name, b.curlevel+1,
havechild =(
case
when exists(select 1 from T_DeptInfo where T_DeptInfo.parent_dept_id = a.dept_id ) then 1
else 0
end
)
from
dbo.T_DeptInfo a
inner join
tem_table b
on (a.parent_dept_id = b.dept_id)
)
select * from tem_table; --3,递归完成后,一定不能少了这句查询语句,否则会报错

树形递归查询是否包含子节点的查询结果

 
 

SQL server 树形递归查询的更多相关文章

  1. [SQL Server]树形结构的创建

    对于SQL Server来说,构建显示一个树形结构不是一件容易的事情,逻辑构造能力不是它的强项.不过也不是说它没有能力干这个事情,只要换一种思维方式就可以理解它的工作原理. 例如,现在有一张表的内容如 ...

  2. SQL Server CTE 递归查询全解

    在TSQL脚本中,也能实现递归查询,SQL Server提供CTE(Common Table Expression),只需要编写少量的代码,就能实现递归查询,本文详细介绍CTE递归调用的特性和使用示例 ...

  3. SQL Server CTE 递归查询全解 -- 转 学习

    在TSQL脚本中,也能实现递归查询,SQL Server提供CTE(Common Table Expression),只需要编写少量的代码,就能实现递归查询,本文详细介绍CTE递归调用的特性和使用示例 ...

  4. SQL Server CTE 递归查询全解(转载)

    在TSQL脚本中,也能实现递归查询,SQL Server提供CTE(Common Table Expression),只需要编写少量的代码,就能实现递归查询,本文详细介绍CTE递归调用的特性和使用示例 ...

  5. SQL Server 树形表非循环递归查询

    很多人可能想要查询整个树形表关联的内容都会通过循环递归来查...事实上在微软在SQL2005或以上版本就能用别的语法进行查询,下面是示例.   --通过子节点查询父节点WITH  TREE AS(  ...

  6. SQL Server 实现递归查询

    基础数据/表结构                 Sql 语句 ;With cte(id,pid,TName)As ( Select id,pid,TName Union All Select B.i ...

  7. SQL SERVER树形结构数据——批量删除分组数据

    定义函数获取某结点下所有子结点: CREATE FUNCTION [dbo].[fn_GetSubGroupInfoById] ( @id AS INT --某分组Id ) RETURNS @SubG ...

  8. SQL SERVER递归查询

    SQL SERVER 进行递归查询 有如下数据表

  9. MS SQL Server递归查询

    原文:MS SQL Server递归查询 刚才在论坛上看到网友一个要求.参考如下,Insus.NET分析一下,可以使用MS SQL Server的递归查询,得到结果.准备一张表: 根据网友提供的数据, ...

  10. 项目升级-oracle改版sql server问题点汇总

    目录 1.符号使用 1.1 :->@ 1.2 mod()->% 1.3 ||->+ 1.4 off等表别名 1.5 columnnum=1->top 1 1.6 minus-& ...

随机推荐

  1. 记录--开局一张图,构建神奇的 CSS 效果

    这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 假设,我们有这样一张 Gif 图: 利用 CSS,我们尝试来搞一些事情. 图片的 Glitch Art 风 在这篇文章中 --CSS 故障 ...

  2. 《.NET内存管理宝典 》(Pro .NET Memory Management) 阅读指南 - 第4章

    本章勘误: 暂无,等待细心的你告诉我哦. 本章注解: 暂无 本章释疑: 暂无,等待你的提问 致谢: MVP 林德熙 MVP 吕毅 sPhinX 相关链接 试读记录

  3. 聊聊大模型"打字机"效果的背后技术——SSE

    SSE:Server Sent Event:服务器发送事件. Server-Sent Events(SSE)是一种由服务器向客户端推送实时数据的技术.它是构建基于事件的.服务器到客户端的通信的一种方法 ...

  4. read IEEE standard for verilog(3)

    read IEEE std for verilog 1.阅读准备 在阅读的第二部分读到了lexical conventions,这次计划读一节.也就是把lexical conventions读完. 2 ...

  5. KingbaseES V8R6 最老事务阻止vacuum freeze

    前言 最近生产环境发生几次由于长事务导致表.库年龄没法回收的情况.我们要规避这种情况的发生,不要等发生了再去强制中断会话连接. 当数据库中存在最老事务版本xmin,那么早于他的快照可以被标记为froz ...

  6. KingbaseES 中的xmin,xmax等系统字段说明

    在KingbaseES中,当我们创建一个数据表时,数据库会隐式增加几个系统字段.这些字段由系统进行维护,用户一般不会感知它们的存在. 例如,以下语句创建了一个简单的表: create table te ...

  7. #威佐夫博弈#洛谷 2252 [SHOI2002]取石子游戏

    题目 有两堆石子,数量任意,可以不同.游戏开始由两个人轮流取石子. 游戏规定,每次有两种不同的取法,一是可以在任意的一堆中取走任意多的石子: 二是可以在两堆中同时取走相同数量的石子.最后把石子全部取完 ...

  8. 小师妹学JavaIO之:文件写入那些事

    目录 简介 字符输出和字节输出 格式化输出 输出其他对象 在特定的位置写入 给文件加锁 总结 简介 小师妹又对F师兄提了一大堆奇奇怪怪的需求,要格式化输出,要特定的编码输出,要自己定位输出,什么?还要 ...

  9. OpenHarmony 3.2 Beta源码分析之MediaLibrary

    1.MediaLibrary介绍 OpenAtom OpenHarmony(以下简称"OpenHarmony")MediaLibrary媒体库提供了一系列易用的接口用于获取媒体文件 ...

  10. 上新啦KIT

    HMS Core上新啦!分析服务区服分析全新上线:机器学习服务OCR新增手写识别服务:3D建模续扫能力更新:视频编辑服务支持自定义上传素材--更多#HMS Core#能力可点击网页链接了解. 了解更多 ...