ITPub博客

首页 > Linux操作系统 > Linux操作系统 > Start with...Connect By函数

Start with...Connect By函数

原创 Linux操作系统 作者:zhanghuipop 时间:2009-10-20 18:15:39 0 删除 编辑

OracleStart with...Connect By子句递归查询

Start with...Connect By子句递归查询一般用于一个表维护树形结构的应用。

创建示例表:

CREATE TABLE TBL_TEST

(

  ID    NUMBER,

  NAME  VARCHAR2(100 BYTE),

  PID   NUMBER                                  DEFAULT 0

);

 

插入测试数据:

INSERT INTO TBL_TEST(ID,NAME,PID) VALUES('1','10','0');

INSERT INTO TBL_TEST(ID,NAME,PID) VALUES('2','11','1');

INSERT INTO TBL_TEST(ID,NAME,PID) VALUES('3','20','0');

INSERT INTO TBL_TEST(ID,NAME,PID) VALUES('4','12','1');

INSERT INTO TBL_TEST(ID,NAME,PID) VALUES('5','121','2');

 

Root往树末梢递归

select * from TBL_TEST

 start with id=1

 connect by prior id = pid

 

从末梢往树ROOT递归

select * from TBL_TEST

 start with id=5

 connect by prior pid = id

 

 

START WITH...CONNECT BY PRIOR子句实现递归查询收藏

oracle中的select语句可以用START WITH...CONNECT BY PRIOR子句实现递归查询,connect by 是结构化查询中用到的,其基本语法是:

 

select ... from tablename start with cond1

connect by cond2

where cond3;

 

简单说来是将一个树状结构存储在一张表里,比如一个表中存在两个字段:

id,parentid那么通过表示每一条记录的parent是谁,就可以形成一个树状结构。

 

用上述语法的查询可以取得这棵树的所有记录。

 

其中COND1是根结点的限定语句,当然可以放宽限定条件,以取得多个根结点,实际就是多棵树。

 

COND2是连接条件,其中用PRIOR表示上一条记录,比如 CONNECT BY PRIOR ID=PRAENTID就是说上一条记录的ID是本条记录的PRAENTID,即本记录的父亲是上一条记录。

COND3是过滤条件,用于对返回的所有记录进行过滤。

 

对于oracle进行简单树查询(递归查询)

DEPTID PAREDEPTID NAME

NUMBER NUMBER CHAR (40 Byte)

部门id 父部门id(所属部门id) 部门名称

 

通过子节点向根节点追朔.

select * from persons.dept start with deptid=76 connect by prior paredeptid=deptid

 

通过根节点遍历子节点.

select * from persons.dept start with paredeptid=0 connect by prior deptid=paredeptid

 

可通过level 关键字查询所在层次.

select a.*,level from persons.dept a start with paredeptid=0 connect by prior deptid=paredeptid

 

PSstart with 后面所跟的就是就是递归的种子,也就是递归开始的地方;

connect by  prior后面的字段顺序是有讲究的;若prior缺省:则只能查询到符合条件的起始行,并不进行递归查询;

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/14613712/viewspace-617038/,如需转载,请注明出处,否则将追究法律责任。

上一篇: Lag和Lead函数
下一篇: 没有了~
请登录后发表评论 登录
全部评论

注册时间:2009-10-14

  • 博文量
    21
  • 访问量
    35374