Hierarchical Queries in Oracle

2021/9/26 19:11:00

本文主要是介绍Hierarchical Queries in Oracle,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

有一些表存在层级关系,例如Oracle的示例表hr.employees:

LAST_NAMEEMPLOYEE_IDMANAGER_ID
King100-
Kochhar101100
De Haan102100
Hunold103102
Ernst104103

可以看到每个员工有自己的manager,从而形成类似这样的层级关系:

Description of Figure 9-1 follows

 King是最大的领导,因此他就是root,下面有其它小领导并形成了分支和层级。下面来看Oracle提供的Hierarchical Queries能做什么。

SELECT last_name, employee_id, manager_id
FROM hr.employees
CONNECT BY PRIOR employee_id = manager_id

这里connect by prior表明了层级关系是怎么形成的。注意这里仅仅是表明关系,查询结果并不会因为该子句发生变化。

SELECT last_name, employee_id, manager_id, LEVEL
FROM hr.employees
CONNECT BY PRIOR employee_id = manager_id

这里level伪列表明了层级关系,查询结果是:

LAST_NAMEEMPLOYEE_IDMANAGER_IDLEVEL
Kochhar1011001
Greenberg1081012
Faviet1091083
Popp1131083

可以看到Kochhar的领导是100,因此他是level 1,Greenberg是领导是101,因此他是level 2。注意这里由于最大的领导king没有领导了,因此没有显示出来。如果要显示King的层级,则:

SELECT last_name, employee_id, manager_id, LEVEL
FROM hr.employees
START WITH employee_id = 100
CONNECT BY PRIOR employee_id = manager_id

表示从root开始计算level,结果是:

LAST_NAMEEMPLOYEE_IDMANAGER_IDLEVEL
King100-1
Kochhar1011002
Greenberg1081013
Faviet1091084

最后一个要说明的功能是排序。除了可以使用普通的排序外,这里还支持order siblings by:

SELECT last_name, employee_id, manager_id, LEVEL
FROM hr.employees
START WITH employee_id = 100
CONNECT BY PRIOR employee_id = manager_id
ORDER SIBLINGS BY last_name;

sibling的英文是兄弟姐妹,因此表示在同一个level下的,同一分支下的所有成员按照last_name排序。对应文章最开始的树状结构,就是2,7,9这三个人按last name排序显示(因为他们相当于兄弟姐妹),5,6按ast name排序显示,但11不参与5,6的排序。

查询结果如下。可以看到同为level 2,Cambrault,De Haan和Errazuriz并没有显示在一起,但显然他们是有序的(c在前,然后是d,e)。而manager都是148的员工(因为在一个分支下,互为兄弟姐妹)则按照last name排序显示(由于这一支在level 3就到头了,所以这6个员工全部排在一起)。

LAST_NAMEEMPLOYEE_IDMANAGER_IDLEVEL
King100-1
Cambrault1481002
Bates1721483
Bloom1691483
Fox1701483
Kumar1731483
Ozer1681483
Smith1711483
De Haan1021002
Hunold1031023
Austin1051034
Ernst1041034
Lorentz1071034
Pataballa1061034
Errazuriz1471002
Ande1661473
Banda1671473

观察结果的顺序,相当于从root开始遍历,遍历完一个分支之后,遍历下一个分支:最开始是king,他有三个下属:Cambrault,De Haan和Errazuriz(按last name排序)。因此从Cambrault开始遍历,紧接着是Cambrault的6个下属(都按last name排序)。由于这支到level 3就结束了,因此回到king的第二个下属De Haan,继续往下遍历,直到遍历完所有的成员。



这篇关于Hierarchical Queries in Oracle的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程