例: Java代码6 m0 C; \( m2 O+ x! S8 c5 ~$ @
select * from table7 Q7 v& C( M( j3 z5 F7 `
start with org_id = 'HBHqfWGWPy'3 @6 ]$ A1 o5 Y [& Y
connect by prior org_id = parent_id;0 J) n( G# t, U L2 V+ T
简单说来是将一个树状结构存储在一张表里,比如一个表中存在两个字段:4 e- `' _6 d |+ I$ B5 [3 }. p
org_id,parent_id那么通过表示每一条记录的parent是谁,就可以形成一个树状结构。$ L! x5 E8 g1 S& M$ B
用上述语法的查询可以取得这棵树的所有记录。# ]: k6 a' I* b( t
其中:
( H7 t) V, p' @+ `) ?) {. T# L 条件1 是根结点的限定语句,当然可以放宽限定条件,以取得多个根结点,实际就是多棵树。- n1 T# z* T8 p+ y7 I A8 h
条件2 是连接条件,其中用PRIOR表示上一条记录,
5 ]3 ^* E' o5 y8 A4 t. x 比如 CONNECT BY PRIOR org_id = parent_id就是说上一条记录的org_id 是本条记录的parent_id,即本记录的父亲是上一条记录。7 E; D* {$ {& ]8 z( s
条件3 是过滤条件,用于对返回的所有记录进行过滤。6 A0 G# z: H: P. Q9 d
简单介绍如下:
& G) u) w" E/ { 在扫描树结构表时,需要依此访问树结构的每个节点,一个节点只能访问一次,其访问的步骤如下:
, e+ C4 U3 g* c' J( _ 第一步:从根节点开始;$ i7 p3 J+ h. [1 F- P& g0 K$ I
第二步:访问该节点;
) W+ ~ j" _4 w4 l+ h" ^8 `$ y2 R$ q 第三步:判断该节点有无未被访问的子节点,若有,则转向它最左侧的未被访问的子节点,并执行第二步,否则执行第四步;( |, E$ {% W7 Q, ^: I9 L- h
第四步:若该节点为根节点,则访问完毕,否则执行第五步;; u Z4 x1 ~+ b8 O9 c
第五步:返回到该节点的父节点,并执行第三步骤。$ C1 @ a! s6 Y" t4 W$ p; F! x' N% c
总之:扫描整个树结构的过程也即是中序遍历树的过程。
$ m' P/ o: q! ~0 W: { 1.树结构的描述( i- y. H4 f/ F u7 T# L+ @
树结构的数据存放在表中,数据之间的层次关系即父子关系,通过表中的列与列间的关系来描述,如 EMP 表中的 EMPNO 和 MGR 。 EMPNO 表示该雇员的编号, MGR 表示领导该雇员的人的编号,即子节点的 MGR 值等于父节点的 EMPNO 值。在表的每一行中都有一个表示父节点的 MGR (除根节点外),通过每个节点的父节点,就可以确定整个树结构。
4 J3 z- j' C. d) {# @ 在 SELECT 命令中使用 CONNECT BY 和 START WITH 子句可以查询表中的树型结构关系。其命令格式如下:; X6 P4 `/ Y/ Z9 w6 h! Y- R9 O
SELECT 。。。
' Z% q; `. ^) r1 Z7 U2 X P CONNECT BY {PRIOR列名1=列名2|列名1=PRIOR裂名2}1 A z( C6 d+ v2 a1 Q" X. I( X
[START WITH];6 T4 Q5 [0 Z- c0 f" {4 V
其中: CONNECT BY 子句说明每行数据将是按层次顺序检索,并规定将表中的数据连入树型结构的关系中。 PRIORY 运算符必须放置在连接关系的两列中某一个的前面。对于节点间的父子关系, PRIOR 运算符在一侧表示父节点,在另一侧表示子节点,从而确定查找树结构是的顺序是自顶向下还是自底向上。在连接关系中,除了可以使用列名外,还允许使用列表达式。 START WITH 子句为可选项,用来标识哪个节点作为查找树型结构的根节点。若该子句被省略,则表示所有满足查询条件的行作为根节点。
/ d+ _, b/ T X0 | START WITH: 不但可以指定一个根节点,还可以指定多个根节点。
/ N5 X# C3 }% g 2.关于PRIOR
# V5 {6 x# `/ G& h: b 运算符 PRIOR 被放置于等号前后的位置,决定着查询时的检索顺序。" P# |! O5 ^$ v3 I
PRIOR 被置于 CONNECT BY 子句中等号的前面时,则强制从根节点到叶节点的顺序检索,即由父节点向子节点方向通过树结构,我们称之为自顶向下 的方式。如:" U: z) \% ?+ q& d
Java代码0 h# K. T+ I/ {2 ]0 e4 F* N5 m
CONNECT BY PRIOR EMPNO=MGR
) s. F* _; Q: m! J9 \# i PIROR 运算符被置于 CONNECT BY 子句中等号的后面时,则强制从叶节点到根节点的顺序检索,即由子节点向父节点方向通过树结构,我们称之为自底向上 的方式。例如:
' b% e0 k# R9 L9 @/ [% @7 _ Java代码
y6 E8 ^3 J2 U CONNECT BY EMPNO=PRIOR MGR
$ n! Q2 ^% b# V 在这种方式中也应指定一个开始的节点。 |