a我考网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 78|回复: 0

[考试辅导] Oracle技术:树型递归的应用(2)

[复制链接]
发表于 2012-8-4 14:06:19 | 显示全部楼层 |阅读模式
例:   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  在这种方式中也应指定一个开始的节点。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|Woexam.Com ( 湘ICP备18023104号 )

GMT+8, 2024-5-24 08:37 , Processed in 0.365615 second(s), 21 queries .

Powered by Discuz! X3.4 Licensed

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表