Oracle 递归查询connect by priop 注解
来源:互联网 发布:sql regexp replace 编辑:程序博客网 时间:2024/06/04 18:44
connect by 是结构化查询中用到的,其基本语法是:
select ... from tablename start by cond1
connect by cond2
where cond3;
简单说来是将一个树状结构存储在一张表里,比如一个表中存在两个字段:
id,parentid那么通过表示每一条记录的parent是谁,就可以形成一个树状结构。
用上述语法的查询可以取得这棵树的所有记录。
其中COND1是根结点的限定语句,当然可以放宽限定条件,以取得多个根结点,实际就是多棵树。
COND2是连接条件,其中用PRIOR表示上一条记录,比如 CONNECT BY PRIOR ID=PRAENTID就是说上一条记录的ID是本条记录的PRAENTID,即本记录的父亲是上一条记录。
COND3是过滤条件,用于对返回的所有记录进行过滤。
PRIOR和START WITH关键字是可选项
PRIORY运算符必须放置在连接关系的两列中某一个的前面。对于节点间的父子关系,PRIOR
运算符在一侧表示父节点,在另一侧表示子节点,从而确定查找树结构是的顺序是自顶向下还是
自底向上。在连接关系中,除了可以使用列名外,还允许使用列表达式。START WITH 子句为
可选项,用来标识哪个节点作为查找树型结构的根节点。若该子句被省略,则表示所有满足查询
条件的行作为根节点。
完整的例子如SELECT PID,ID,NAME FROM T_WF_ENG_WFKIND START WITH PID =0 CONNECT BY PRIOR ID = PID
自底向上查询
自顶向下查询
select ... from tablename start by cond1
connect by cond2
where cond3;
简单说来是将一个树状结构存储在一张表里,比如一个表中存在两个字段:
id,parentid那么通过表示每一条记录的parent是谁,就可以形成一个树状结构。
用上述语法的查询可以取得这棵树的所有记录。
其中COND1是根结点的限定语句,当然可以放宽限定条件,以取得多个根结点,实际就是多棵树。
COND2是连接条件,其中用PRIOR表示上一条记录,比如 CONNECT BY PRIOR ID=PRAENTID就是说上一条记录的ID是本条记录的PRAENTID,即本记录的父亲是上一条记录。
COND3是过滤条件,用于对返回的所有记录进行过滤。
PRIOR和START WITH关键字是可选项
PRIORY运算符必须放置在连接关系的两列中某一个的前面。对于节点间的父子关系,PRIOR
运算符在一侧表示父节点,在另一侧表示子节点,从而确定查找树结构是的顺序是自顶向下还是
自底向上。在连接关系中,除了可以使用列名外,还允许使用列表达式。START WITH 子句为
可选项,用来标识哪个节点作为查找树型结构的根节点。若该子句被省略,则表示所有满足查询
条件的行作为根节点。
完整的例子如SELECT PID,ID,NAME FROM T_WF_ENG_WFKIND START WITH PID =0 CONNECT BY PRIOR ID = PID
自底向上查询
- select t.*, t.rowid from ad52 t
- start with t.yae049=0104020101 CONNECT BY PRIOR t.yae100=t.yae049
自顶向下查询
- select t.*, t.rowid from ad52 t
- start with t.yae100=0101 CONNECT BY PRIOR t.yae049=t.yae100
- Oracle 递归查询connect by priop 注解
- Oracle递归查询 start with Connect By
- Oracle 递归查询connect by 简单例子
- oracle递归查询 start with...connect by
- oracle start with connect by递归查询
- Oracle 递归查询 Connect by prior
- oracle connect by prior 递归查询
- Oracle Connect By Prior(递归查询)
- oracle connect by递归
- Oracle 递归查询 树查询 start with SQL CONNECT BY
- 级联查询 oracle 中connect by prior实现递归查询
- oracle connect by prior 进行简单树查询(递归查询)
- oracle 递归查询(树查询) connect by prior
- Oracle Connect By 查询
- Oracle用Start with...Connect By子句递归查询
- Oracle用Start with...Connect By子句递归查询
- Oracle Start with...Connect By子句递归查询
- Oracle用Start with...Connect By子句递归查询
- 提高数据库性能,需要注意的某些事项
- HTML5本地存储(Local Storage) 的前世今生(二)
- 29.栈的push、pop 序列
- 如何给屏幕字段(下拉框和输入框)用代码添加F4 search help
- Add XY Data将坐标点批量导入ArcMAP图层,形成新的点图层
- Oracle 递归查询connect by priop 注解
- 错排详解
- poj 2081 Recaman's Sequence
- C++中计算某个代码的运行时间
- 整理的游戏服务器架构资料
- linux rsync 文件同步
- 测试系统:Mac OS X 10.7 Lion GM版
- C#接口
- C# POST访问需要HTTP Digest Authentication认证资源的实现