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

Oralce之递归算法

程序员文章站 2022-06-03 23:06:45
...

Oracle递归算法的经典用途,比如 多级部门下,子部门不能作为父部门的父部门。

Oracle递归算法的经典用途,比如 多级部门下,,子部门不能作为父部门的父部门。

有点拗口,比方说吧,爸爸部门下有甲儿子部门和乙儿子部门,甲或乙儿子部门不能成为爸爸部门的上级部门。

这个是很多管理系统的多级分类下的经典需求。


好吧。给出部门表结构--Department。


判断子部门是否能成为爸爸部门的上级部门,采用到了递归。SQL:

其中 CONNECT BY PRIOR .... START WITH..... 就是递归。 #deptNo# 、#parentNo# 分别代表 子部门 和 爸爸部门。


如果返回值等于1,则子部门不能成为爸爸部门的上级部门;如果返回值不等于1,反之。

Oralce之递归算法