SQL SERVER 2005的递归查询
项目中有用户组表UserGroup如下:
其中PID表示当前组的上级组
表数据如下:
现在想查询出*组[没有上级组叫*组]A1组的所有子孙组ID,SQL如下:
[sql] www.2cto.com
--查询子节点
with
RTD1 as(
select id ,pid from UserGroup
),
RTD2 as(
select * from RTD1 where id=6
union all
select RTD1.* from RTD2 inner join RTD1
on RTD2.id=RTD1.PID
)
select * from RTD2
www.2cto.com
查询结果如下:
id pid
----------- -----------
6 NULL
17 6
18 6
20 6
21 20
22 20
23 20
24 20
29 20
25 23
26 23
28 26
27 25
(13 行受影响)
现在想查询出A1-B3-C3-D2组的所有上级组ID,SQL如下:
[sql]
--查询父节点
with
RTU1 as(
select id ,pid from UserGroup
),
RTU2 as(
select * from RTU1 where id=26
union all
select RTU1.* from RTU2 inner join RTU1
--on myT2.id=myT.PID
on RTU2.PID=RTU1.ID
) www.2cto.com
select * from RTU2
查询结果如下:
id pid
----------- -----------
26 23
23 20
20 6
6 NULL
(4 行受影响)
相关文章
- 同时兼容SQL Server和PostgreSql的分页方式
- 以其他账户打开sql server2016/vs2013/vs2015等出现“此任务要求应用程序具有较高的权限”的解决办法
- SQL Server中查询数据库及表的信息语句
- sql查询数据库中所有表的记录条数,以及占用磁盘空间大小。
- SQL中对连表查询的建议
- SQL Server Log文件对磁盘的写操作大小是多少
- (转)在SQL Server 2016,Visual Studio 2017环境下,连接数据库屡屡失败,在connectionString上出的问题
- Oracle 数据库 查询 执行sql语句的机器名
- (转载)SQL Server 2005 如何启用xp_cmdshell组件
- SQL SERVER实现基本的分页功能