oracle 树形结构查询

oracle树查询的最重要的就是select…start with…connect by…prior语法了。依托于该语法,我们可以将一个表形结构的以树的顺序列出来。在下面列述了oracle中树型查询的常用查询方式以及经常使用的与树查询相关的oracle特性函数等,在这里只涉及到一张表中的树查询方式而不涉及多表中的关联等。
--父菜单
insert into tb_menu(id, title, parent) values(1, '父菜单1',null);

......
--一级菜单
insert into tb_menu(id, title, parent) values(6, '一级菜单6',1);

......
--二级菜单
insert into tb_menu(id, title, parent) values(21, '二级菜单21',6);


parent字段存储的是上级id,如果是顶级父节点,该parent为null(得补充一句,当初的确是这样设计的,不过现在知道,表中最好别有null记录,这会引起全文扫描,建议改成0代替)。

2、树操作
我们从最基本的操作,逐步列出树查询中常见的操作,所有查询出来的节点以家族中的辈份作比方。

1)、查找树中的所有顶级父节点(辈份最长的人)。 假设这个树是个目录结构,那么第一个操作总是找出所有的顶级节点,再根据该节点找到其下属节点。

select * from tb_menu m where m.parent is null;


2)、查找一个节点的直属子节点(所有儿子)。 如果查找的是直属子类节点,也是不用用到树型查询的。

select * from tb_menu m where m.parent=1;


3)、查找一个节点的所有直属子节点(所有后代)。

select * from tb_menu m start with m.id=1 connect by m.parent=prior m.id;


4)、查找一个节点的所有直属父节点(祖宗)。

select * from tb_menu m start with m.id=38 connect by prior m.parent=m.id;


猜你喜欢

转载自lysunki.iteye.com/blog/2204197