欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

求SQL语句递归的算法

程序员文章站 2022-04-21 09:25:31
...

表结构是这样的 部门 上级部门 A B B C C D A A B B C C 求一条SQL语句,根据A查其上级部门,查询结果为 上级部门 B C D ================================================= 用函数 create table tb (部门 varchar(20),上级部门 varchar(20)) insert into tb

表结构是这样的

部门 上级部门
A B
B C
C D
A A
B B
C C

求一条SQL语句,根据A查其上级部门,查询结果为
上级部门
B
C
D

=================================================

用函数
create table tb (部门 varchar(20),上级部门 varchar(20))

insert into tb select 'A','B' union all select 'B','C' union all select 'C','D'
union all select 'A','A' union all select 'B','B' union all select 'C','C'

--select * from tb
create function test_f (@name varchar(20))
returns @ta table(上级部门 varchar(20))
as
begin
--select @name=上级部门 from tb where 部门=@name and 部门!=上级部门
while exists(select 1 from tb where 部门=@name and 部门!=上级部门)
begin
insert @ta select 上级部门 from tb where 部门=@name and 部门!=上级部门
select @name=上级部门 from tb where 部门=@name and 部门!=上级部门
end
return
end

select * from dbo.test_f('A')

删除:
drop function test_f
drop table tb

上级部门
--------------------
B
C
D

(所影响的行数为 3 行)