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