浏览 4754 次
精华帖 (0) :: 良好帖 (1) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2010-01-22
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 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间: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] |
|
返回顶楼 | |