oracle start with 函数

Oracle中start with…connect by prior子句用法

connect by 是结构化查询中用到的,其基本语法是:
select … from tablename
start with 条件1
connect by 条件2
where 条件3;

例:
select * from table
start with org_id = ‘HBHqfWGWPy’
connect by prior org_id = parent_id;

         简单说来是将一个树状结构存储在一张表里,好比一个表中存在两个字段:
org_id,parent_id那么经过表示每一条记录的parent是谁,就能够造成一个树状结构。
        用上述语法的查询能够取得这棵树的全部记录。
        其中:
        条件1 是根结点的限定语句,固然能够放宽限定条件,以取得多个根结点,实际就是多棵树。
        条件2 是链接条件,其中用 PRIOR表示上一条记录,好比 CONNECT BY PRIOR org_id = parent_id;就是说 上一条记录的org_id 是本条记录的parent_id,即本记录的父亲是上一条记录。

        条件3 是过滤条件,用于对返回的全部记录进行过滤。 oracle


从Root往树末梢递归
select * from TBL_TEST
start with id=1
connect by prior id = pid

从末梢往树ROOT递归
select * from TBL_TEST
start with id=5
connect by prior pid = id
=====
对于oracle进行简单树查询(递归查询)

DEPTID PAREDEPTID NAME
NUMBER NUMBER CHAR (40 Byte)
部门id 父部门id(所属部门id) 部门名称

spa

相关文章
相关标签/搜索