您的位置:首页 > 数据库 > Oracle

问题:Oracle 树形遍历;结果:使用oracle进行遍历树操作

2015-10-15 10:39 671 查看
[align=center]使用oracle进行遍历树操作[/align]

1:首先数据库中表必须是树形结构的
2:super_department_id 为 department_id 的父节点编号
3:以下语句的执行结果是:department_id = 88 所有字节点及子子节点的记录

select * from pub_department a start with a.department_id = 88 connect by prior a.department_id = a.super_department_id

Oracle数据库遍历树形结构表

1、从根结点开始找子节点

/*

create table test (id int ,pid int ,name varchar(10));

insert into test values ( 1, 0 ,'n1' );

insert into test values( 2, 1 ,'n12');

insert into test values( 3, 1 ,'n13');

insert into test values( 4, 2 ,'n21');

insert into test values( 5, 2 ,'n22');

insert into test values( 6, 3 ,'n31');

insert into test values( 7, 3 ,'n32');

insert into test values( 8, 4 ,'n211');

insert into test values( 9, 4 ,'n212');

*/

/*

从根结点开始找子节点(可以指定节点层级)

*/

select id,pid,name ,level from test

--where level =3

start with id =2

connect by prior id = pid;

2、从叶结点开始找根节点

/*

create table test (id int ,pid int ,name varchar(10));

insert into test values ( 1, 0 ,'n1' );

insert into test values( 2, 1 ,'n12');

insert into test values( 3, 1 ,'n13');

insert into test values( 4, 2 ,'n21');

insert into test values( 5, 2 ,'n22');

insert into test values( 6, 3 ,'n31');

insert into test values( 7, 3 ,'n32');

insert into test values( 8, 4 ,'n211');

insert into test values( 9, 4 ,'n212');

*/

/*

从叶结点开始找根节点

prior 关键字 与谁放在一起,就是找谁

根节点的父节点不能是他本身,那会造成死循环

*/

select * from test /*where conditions*/

start with id=7

connect by id = prior pid;

ORA-01436: 用户数据中的 CONNECT BY 循环

今天在群里有个朋友问了

起始地 目的地 距离(公里)
A B 1000
A C 1100
A D 900
A E 400
B D 300
D F 600
E A 400
F G 1000
C B 600
请用SQL语句或一段代码写出从A出发,可达到的目的地(包括间接方式)。
这样的问题

create table dest(
sid char(1),
eid char(1),
distance int);
insert into dest values('A','B',1000);
insert into dest values('A','C',1100);
insert into dest values('A','D',900);
insert into dest values('A','E',400);
insert into dest values('B','D',300);
insert into dest values('D','F',600);
insert into dest values('E','A',400);
insert into dest values('F','G',1000);
insert into dest values('C','B',600);

很自然的就会想到

select sid from dest connect by prior eid=sid start with sid='A';

但是在运行时提示:ORA-01436: 用户数据中的 CONNECT BY 循环

这是a到e,又从e到a,有死循环......

解决方法:

SELECT distinct eid
FROM dest
START WITH SID='A'
connect by nocycle prior eid=sid

原来connect by里还有nocycle
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: