增强plsql developer的session monitor工具_第1页
增强plsql developer的session monitor工具_第2页
增强plsql developer的session monitor工具_第3页
增强plsql developer的session monitor工具_第4页
增强plsql developer的session monitor工具_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、树结构查询ORACLE是一个关系数据库管理系统,它用表的形式组织数据,在某些表中的数据还呈现出 树型结构的联系。例如,我们现在讨论雇员信息表EMP,其中含有雇员编号(EMPNO)和 经理(MGR)两例,通过这两列反映出来的就是雇员之间领导和被领导的关系。有些雇员 领导另一些雇员,有些雇员被领导,还有些雇员领导一些人又被别人领导,他们之间的这种 关系就是一种树结构,图1.1表示了 EMP表雇员间的这种树结构。MGR=7839EMPNO=9698MGR=7839MGR=7839EMPNO=7566MGR=7788MGR=7902ADAMSSMITHEMPNO=7876图1.1 EMP表树结构图EM

2、PNO=7369EMPNO=7782JONESBLAKECLARKMGR=7566MGR=7566MGR=7698MGR=7698MGR=7698MGR=7698MGR=7698MGR=7782SCOTTFORDALLENWARDMARTINTURNERJAMESMILLEREMPNO=7788 EMPNO=7902EMPNO=7499EMPNO=7521EMPNO=9654EMPNO=7844EMPNO=7900EMPNO=7934在这个树结构中,如果一个节点有直接的下属节点(如图中的JONES有碍SCOTT和 FORD),那么称该节点是下属节点的父节点,下属节点为该节点的子节点。通过雇员的

3、 EMPNO和MGR可以看出他们之间的父子节点关系,父节点的EMPNO与子节点的MGR 相同。在树结构中,有且仅有一个节点无父节点,如图中的KING,该节点被称为根节点。 从图上的标记可以看出,只有KING的MGR为空值。除根节点外,任何节点只有一个父节 点,有一个,多个或没有子节点。早扫描树结构表时,需要依此访问树结构的每个节点,一个节点只能访问一次,其访问的步 骤如下:第一步:从根节点开始;第二步:访问该节点;第三步:判断该节点有无未被访问的子节点,若有,则转向它最左侧的未被访问的子节,并 执行第二步,否则执行第四步;第四步:若该节点为根节点,则访问完毕,否则执行第五步;第五步:返回到该节

4、点的父节点,并执行第三步骤。总之:扫描整个树结构的过程也即是中序遍历树的过程。1.树结构的描述树结构的数据存放在表中,数据之间的层次关系即父子关系,通过表中的列与列间的关系来 描述,如EMP表中的EMPNO和MGR。EMPNO表示该雇员的编号,MGR表示领导该雇 员的人的编号,即子节点的MGR值等于父节点的EMPNO值。在表的每一行中都有一个表 示父节点的MGR (除根节点外),通过每个节点的父节点,就可以确定整个树结构。在SELECT命令中使用CONNECT BY和蔼START WITH子句可以查询表中的树型结构关 系。其命令格式如下:SELECT。CONNECT BY PRIOR 列名 1

5、=列名 21 列名 1=PRIOR 裂名 2START WITH;其中:CONNECT BY子句说明每行数据将是按层次顺序检索,并规定将表中的数据连入树 型结构的关系中。PRIORY运算符必须放置在连接关系的两列中某一个的前面。对于节点间 的父子关系,PRIOR运算符在一侧表示父节点,在另一侧表示子节点,从而确定查找树结 构是的顺序是自顶向下还是自底向上。在连接关系中,除了可以使用列名外,还允许使用列 表达式。START WITH子句为可选项,用来标识哪个节点作为查找树型结构的根节点。若 该子句被省略,则表示所有满足查询条件的行作为根节点。例1以树结构方式显示EMP表的数据。SQL SELEC

6、T EMPNO,ENAME,MGRFROM EMPCONNECT BY PRIOR EMPNO=MGRSTART WITH ENAME=KING;EMPNOENAMEMGR7839KING7566JONES78397788SCOTT75667876ADAMS77887902FORD75667369SMITH79027698BLAKE78397499ALLEN76987521WARD76987654MARTIN76987844TURNER76987900JAMES76987782CLARK78397934MILLER778214 rows selected.2.关于 PRIOR运算符PRIOR被

7、放置于等号前后的位置,决定着查询时的检索顺序。PRIOR被置于CONNECT BY子句中等号的前面时,则强制从根节点到叶节点的顺序检索, 即由父节点向子节点方向通过树结构,我们称之为自顶向下的方式。如:CONNECT BY PRIOR EMPNO=MGRPIROR运算符被置于CONNECT BY子句中等号的后面时,则强制从叶节点到根节点的顺 序检索,即由子节点向父节点方向通过树结构,我们称之为自底向上的方式。例如:CONNECT BY EMPNO=PRIOR MGR在这种方式中也应指定一个开始的节点。例2从SMITH节点开始自底向上查找EMP的树结构。SQLSELECT EMPNO,ENAME

8、,MGRFROM EMPCONNECT BY EMPNO=PRIOR MGRSTART WITH ENAME= SMITH;EMPNOENAMEMGR7369SMITH79027902FORD75667566JONES78397839 KING4 rows selected.在这种自底向上的查找过程中,只有树中的一枝被显示,这是因为,在树结构中每一个节点 只允许有一个父节点,其查找过程是从开始节点起,找到其父节点,再由其父节点向上,找 父节点的父节点。这样一直找到根节点为止,结果就是树中一枝的数据。备注:例2的另外一种写法SELECT EMPNO,ENAME,MGRFROM EMPCONNEC

9、T BY PRIOR MGR=EMPNOSTART WITH ENAME= SMITH ;3.定义查找起始节点在自顶向下查询树结构时,不但可以从根节点开始,还可以定义任何节点为起始节 点,以此开始向下查找。这样查找的结果就是以该节点为开始的结构树的一枝。例3查找JONES直接或间接领导的所有雇员信息。SQLSELECT EMPNO,ENAME,MGRFROM EMPCONNECT BY PRIOR EMPNO=MGRSTART WITH ENAME= JONES;EMPNOENAMEMGR7566JONES78397788SCOTT75667876ADAMS77887902FORD756673

10、69SMITH79025 rows selected.START WITH不但可以指定一个根节点,还可以指定多个根节点。例4查找由FORD和BLAKE领导的所有雇员的信息。7844SQLSELECT EMPNO, ENAME, MGRFROM EMPCONNECT BY PRIOR EMPNO=MGRSTART WITH ENAME IN FORD,EMPNOENAME7698BLAKE78397499ALLEN76987521WARD76987654MARTIN7698TURNER76987900JAMES76987902FORD75667369SMITH7902BLAKE );8 rows

11、 selected.在自底向上查询树结构时,也要指定一个开始节点,以此开始向上查找其父节点, 直至找到根节点,其结果将是结构树中的一枝数据。4.使用 LEVEL在具有树结构的表中,每一行数据都是树结构中的一个节点,由于节点所处的层次 位置不同,所以每行记录都可以有一个层号。层号根据节点与根节点的距离确定。不论从哪 个节点开始,该起始根节点的层号始终为1,根节点的子节点为2,依此类推。图1.2就表 示了树结构的层次。KINGJONESCLARK 23SCOTT FORDALLENJAMESADAMS4图案1.2 EMP表树结构层次图层号1BLAKEMILLERWARD MARTINTURNERS

12、MITH在查询中,可以使用伪列LEVEL显示每行数据的有关层次。LEVEL将返回树型 结构中当前节点的层次,我们可以使用LEVEL来控制对树型结构进行遍历的深度。例5显示EMP表中的各行数据及层号。SQLSELECT LEVEL,EMPNO,MGRFROM EMPCONNECT BY PRIOR EMPNO=MGRLEVELEMPNOENAME17839KING27566JONES783937788SCOTT756647876ADAMS778837902FORD756647369SMITH790227698BLAKE783937499ALLEN769837521WARD769837654MAR

13、TIN769837844TURNER769837900JAMES769827782CLARK783937934MILLER778214 rows selected.START WITH ENAME= KING;MGR伪列LEVEL为数值型,可以在SELECT命令中用语各种计算机。例6使用LEVEL改变查询结果的显示形式。SQLCOLUMN EMPLOYEE FORMAT A20SQL SELECT EMPNO,RPAD( ,LEVEL*3) |ENAME EMPLOYEE,MGRFROM EMPCONNECT BY PRIORY EMPNO=EMRSTART WITH ENAME=KING;M

14、GREMPNOEMPLOYEE7840KING7566JONES78397788SCOTT75667876ADAMS77887902FORD75667369SMITH79027698BLAKE78397499ALLEN76987521WARD76987654MARTIN76987844TURNER76987900JAMES76987782CLARK78397934MILLER778214 rows selected.在SELECT使用了函数RPAD,该函数表示以LEVEL*3个空格进行填充,由于不同行处于 不同的节点位置,具有不同的LEVEL值,因此填充的空格数将根据各自的层号确定,空格 再与

15、雇员名字拼接,结果显示出这种层次关系,也就是说其雇员名字右侧填充的空格数与它 的层数有关。5.节点和分支的裁剪在对树结构进行查询时,可以去掉表中的某些行,也可以剪掉树中的一个分支,使用WHERE 子句来限定树型结构中的单个节点,以去掉树中的单个节点,但它却不影响其后代节点(自 顶向下检索时)或前辈节点(自底向顶检索时)。SQLCOLUMN EMPLOYEE FORMAT A20SQL SELECT EMPNO,RPAD( ,LEVEL*3) |ENAME EMPLOYEE,MGRFROM EMPWHERE ENAME!=SCOTTCONNECT BY PRIORY EMPNO=EMRSTART

16、 WITH ENAME=KING;EMPNO7841756678767902736976987499752176547844790077827934EMPLOYEEMGRKINGJONES7839ADAMS7788FORD7566SMITH7902BLAKE7839ALLEN7698WARD7698MARTIN7698TURNER7698JAMES7698CLARK7839MILLER778213 rows selected.在这个查询中,仅剪去了树中单个节点SCOTT。若希望剪去树结构中的某个分支,则要用 CONNECT BY子句。CONNECT BY子句是限定树型结构中的整个分支,既要剪除

17、分支上 的单个节点,也要剪除其后代节点(自顶向下检索时)或前辈节点(自底向顶检索时)。例8.显示KING领导下的全体雇员信息,除去SCOTT领导的一支。SQL SELECT EMPNO,RPAD( ,LEVEL*3) |ENAMi EMPLOYEE,MGRFROM EMPCONNECT BY PRIORY EMPNO=EMRAND ENAME!=SCOTTSTART WITH ENAME=KING;EMPNO7842756679027369769874997521EMPLOYEEMGRKINGJONES7839FORD7566SMITH7902BLAKE7839ALLEN7698WARD769

18、87654MARTIN76987844TURNER76987900JAMES769877827934CLARKMILLER7839778212 rows selected.这个查询结果就与例7不同,除了剪去单个节点SCOTT外,还将SCOTT的子节点ADAMS 剪掉,即把SCOTT这个分支剪掉了。当然WHERE子句可以和CONNECT BY子句联合使用,这样能够同时剪掉单个节点和树中 的某个分支。例9.显示KING领导全体雇员信息,除去雇员SCOTT,以及BLAKE领导的一支。SQLCOLUMN EMPLOYEE FORMAT A20SQL SELECT EMPNO,RPAD( ,LEVEL*3) |ENAME EMPLOYEE,MGRFROM EMPWHERE ENAME!=SCOTTCONNECT BY PRIORY EMPNO=EMREMPNOEMPLOYEEMGR7843KING7566JONES78397876ADAMS77887902FORD75667369SMITH79027782CLARK783979347 rows selected.6.排序显示MILLER7782AND ENAME!=BLAKESTART WI

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论