Oracle中connect by prior .... start with

一 connect by prior ....start with

 废话少说上测试代码.

        

create table test_table_c(id number primary key,description varchar(255),parent_id number);
insert into test_table_c(id,description,parent_id) values(1,'cuiyaonan2',null);
insert into test_table_c(id,description,parent_id) values(2,'cuiyaonan20',1);
insert into test_table_c(id,description,parent_id) values(3,'cuiyaonan200',2);
insert into test_table_c(id,description,parent_id) values(4,'cuiyaonan2000',3);
insert into test_table_c(id,description,parent_id) values(5,'cuiyaonan2000@',4);
insert into test_table_c(id,description,parent_id) values(6,'cuiyaonan2000@1',5);
insert into test_table_c(id,description,parent_id) values(7,'cuiyaonan2000@16',6);

 显示结果为



 

 

执行语句

 

select * from test_table_c connect by prior parent_id  =  id  start with id =7;

 显示结果为:



 

 

执行语句

 

select * from test_table_c connect by parent_id  =  prior id  start with id =1;

 显示结果



 

 

注释 :prior  表示上一条记录. prior +字段 表示上一条记录的某个字段.如 

 parent_id  =  prior id 

表示上一条记录的id与本条记录的parent_id值是否一致.

 

猜你喜欢

转载自cuiyaoonan2000.iteye.com/blog/1790922