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/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/24870090/viewspace-982884/