Oracle求下级机构,怎么得到所有下级id

SQL code-- 树形数据深度排序处理示例(递归法)

--测试数据

CREATE TABLE tb(ID char(3),PID char(3),Name nvarchar(10))

INSERT tb SELECT '001',NULL ,'山东省'

UNION ALL SELECT '002','001','烟台市'

UNION ALL SELECT '004','002','招远市'

UNION ALL SELECT '003','001','青岛市'

UNION ALL SELECT '005',NULL ,'四会市'

UNION ALL SELECT '006','005','清远市'

UNION ALL SELECT '007','006','小分市'

GO

--广度搜索排序函数

CREATE FUNCTION f_Sort(@ID char(3)=NULL,@sort int=1)

RETURNS @t_Level TABLE(ID char(3),sort int)

AS

BEGIN

DECLARE tb CURSOR LOCAL

FOR

SELECT ID FROM tb

WHERE PID=@ID

OR(@ID IS NULL AND PID IS NULL)

OPEN TB

FETCH tb INTO @ID

WHILE @@FETCH_STATUS=0

BEGIN

INSERT @t_Level VALUES(@ID,@sort)

SET @sort=@sort+1

IF @@NESTLEVEL<32 --如果递归层数未超过32层(递归最大允许32层)

BEGIN

--递归查找当前节点的子节点

INSERT @t_Level SELECT * FROM f_Sort(@ID,@sort)

SET @sort=@sort+@@ROWCOUNT --排序号加上子节点个数

END

FETCH tb INTO @ID

END

RETURN

END

GO

--显示结果

SELECT a.*

FROM tb a,f_Sort(DEFAULT,DEFAULT) b

WHERE a.ID=b.ID

ORDER BY b.sort

/*--结果

ID PID Name

------ --------- ----------

001 NULL 山东省

002 001 烟台市

004 002 招远市

003 001 青岛市

005 NULL 四会市

006 005 清远市

007 006 小分市

--*/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值