ITPub博客

首页 > 数字化转型 > ERP > START WITH...CONNECT BY PRIOR简单使用

START WITH...CONNECT BY PRIOR简单使用

原创 ERP 作者: 时间:2007-11-17 17:08:38 0 删除 编辑

START WITH...CONNECT BY PRIOR简单使用

[@more@]

1、测试环境的建立

SQL> CREATE TABLE TBL_TEST
2 (
3 ID NUMBER,
4 NAME VARCHAR2(10),
5 PID NUMBER
6 );

表已创建。

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

已创建 1 行。

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

已创建 1 行。

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

已创建 1 行。

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

已创建 1 行。

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

已创建 1 行。

SQL> INSERT INTO TBL_TEST(ID,NAME,PID) VALUES('6','121','3');

已创建 1 行。


从树根到树叶:

SQL> select * from TBL_TEST
2 start with id=1
3 connect by prior id = pid;

ID NAME PID
---------- ---------- ----------
1 10 0
2 11 1
5 121 2
4 12 1


从树叶到树根:
SQL> select * from TBL_TEST
2 start with id=5
3 connect by prior pid = id;

ID NAME PID
---------- ---------- ----------
5 121 2
2 11 1
1 10 0

connect by 是结构化查询中用到的,其基本语法是:
select ... from tablename start by cond1
connect by cond2
where cond3;

简单说来是将一个树状结构存储在一张表里

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

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

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

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

上一篇: 没有了~
请登录后发表评论 登录
全部评论
  • 博文量
    89
  • 访问量
    369505