SQL server 树形递归查询
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 树形递归查询的更多相关文章
- [SQL Server]树形结构的创建
对于SQL Server来说,构建显示一个树形结构不是一件容易的事情,逻辑构造能力不是它的强项.不过也不是说它没有能力干这个事情,只要换一种思维方式就可以理解它的工作原理. 例如,现在有一张表的内容如 ...
- SQL Server CTE 递归查询全解
在TSQL脚本中,也能实现递归查询,SQL Server提供CTE(Common Table Expression),只需要编写少量的代码,就能实现递归查询,本文详细介绍CTE递归调用的特性和使用示例 ...
- SQL Server CTE 递归查询全解 -- 转 学习
在TSQL脚本中,也能实现递归查询,SQL Server提供CTE(Common Table Expression),只需要编写少量的代码,就能实现递归查询,本文详细介绍CTE递归调用的特性和使用示例 ...
- SQL Server CTE 递归查询全解(转载)
在TSQL脚本中,也能实现递归查询,SQL Server提供CTE(Common Table Expression),只需要编写少量的代码,就能实现递归查询,本文详细介绍CTE递归调用的特性和使用示例 ...
- SQL Server 树形表非循环递归查询
很多人可能想要查询整个树形表关联的内容都会通过循环递归来查...事实上在微软在SQL2005或以上版本就能用别的语法进行查询,下面是示例. --通过子节点查询父节点WITH TREE AS( ...
- SQL Server 实现递归查询
基础数据/表结构 Sql 语句 ;With cte(id,pid,TName)As ( Select id,pid,TName Union All Select B.i ...
- SQL SERVER树形结构数据——批量删除分组数据
定义函数获取某结点下所有子结点: CREATE FUNCTION [dbo].[fn_GetSubGroupInfoById] ( @id AS INT --某分组Id ) RETURNS @SubG ...
- SQL SERVER递归查询
SQL SERVER 进行递归查询 有如下数据表
- MS SQL Server递归查询
原文:MS SQL Server递归查询 刚才在论坛上看到网友一个要求.参考如下,Insus.NET分析一下,可以使用MS SQL Server的递归查询,得到结果.准备一张表: 根据网友提供的数据, ...
- 项目升级-oracle改版sql server问题点汇总
目录 1.符号使用 1.1 :->@ 1.2 mod()->% 1.3 ||->+ 1.4 off等表别名 1.5 columnnum=1->top 1 1.6 minus-& ...
随机推荐
- 记录--开局一张图,构建神奇的 CSS 效果
这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 假设,我们有这样一张 Gif 图: 利用 CSS,我们尝试来搞一些事情. 图片的 Glitch Art 风 在这篇文章中 --CSS 故障 ...
- 《.NET内存管理宝典 》(Pro .NET Memory Management) 阅读指南 - 第4章
本章勘误: 暂无,等待细心的你告诉我哦. 本章注解: 暂无 本章释疑: 暂无,等待你的提问 致谢: MVP 林德熙 MVP 吕毅 sPhinX 相关链接 试读记录
- 聊聊大模型"打字机"效果的背后技术——SSE
SSE:Server Sent Event:服务器发送事件. Server-Sent Events(SSE)是一种由服务器向客户端推送实时数据的技术.它是构建基于事件的.服务器到客户端的通信的一种方法 ...
- read IEEE standard for verilog(3)
read IEEE std for verilog 1.阅读准备 在阅读的第二部分读到了lexical conventions,这次计划读一节.也就是把lexical conventions读完. 2 ...
- KingbaseES V8R6 最老事务阻止vacuum freeze
前言 最近生产环境发生几次由于长事务导致表.库年龄没法回收的情况.我们要规避这种情况的发生,不要等发生了再去强制中断会话连接. 当数据库中存在最老事务版本xmin,那么早于他的快照可以被标记为froz ...
- KingbaseES 中的xmin,xmax等系统字段说明
在KingbaseES中,当我们创建一个数据表时,数据库会隐式增加几个系统字段.这些字段由系统进行维护,用户一般不会感知它们的存在. 例如,以下语句创建了一个简单的表: create table te ...
- #威佐夫博弈#洛谷 2252 [SHOI2002]取石子游戏
题目 有两堆石子,数量任意,可以不同.游戏开始由两个人轮流取石子. 游戏规定,每次有两种不同的取法,一是可以在任意的一堆中取走任意多的石子: 二是可以在两堆中同时取走相同数量的石子.最后把石子全部取完 ...
- 小师妹学JavaIO之:文件写入那些事
目录 简介 字符输出和字节输出 格式化输出 输出其他对象 在特定的位置写入 给文件加锁 总结 简介 小师妹又对F师兄提了一大堆奇奇怪怪的需求,要格式化输出,要特定的编码输出,要自己定位输出,什么?还要 ...
- OpenHarmony 3.2 Beta源码分析之MediaLibrary
1.MediaLibrary介绍 OpenAtom OpenHarmony(以下简称"OpenHarmony")MediaLibrary媒体库提供了一系列易用的接口用于获取媒体文件 ...
- 上新啦KIT
HMS Core上新啦!分析服务区服分析全新上线:机器学习服务OCR新增手写识别服务:3D建模续扫能力更新:视频编辑服务支持自定义上传素材--更多#HMS Core#能力可点击网页链接了解. 了解更多 ...