论坛首页 综合技术论坛

Oracle 递归查询connect by priop 注解

浏览 4739 次
精华帖 (0) :: 良好帖 (1) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2010-01-22  
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 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



  • 大小: 17.9 KB
  • 大小: 49.4 KB
   发表时间:2010-06-18  
今天发现如果菜单的ID都是依次有规律的编的话,可以使用like模糊子句很方便的查询。
以前一般的like子句是这样写的:
select t.* from ad52 t 
WHERE t.yae049  LIKE '01040103%' 	 ORDER BY t.yae049

但这样得不到我们想要的树型菜单,改变一下

select t.* from ad52 t 
WHERE '01040103' LIKE t.yae049 || '%' ORDER BY t.yae049


查询结果

[img]http://dl.iteye.com/upload/picture/pic/65299/8b71b3f2-4c00-3555-8b7b-0439adf83666.jpg [/img]
0 请登录后投票
论坛首页 综合技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics