zoukankan      html  css  js  c++  java
  • Oracel中Start with 用法

    参考:https://blog.csdn.net/qq_39986274/article/details/81033704

    SELECT ... FROM    + 表名 
    START WITH         + 条件1
    CONNECT BY PRIOR   + 条件2
    WHERE              + 条件3

    条件1:是根节点的限定语句,当然可以放宽限定条件,以取得多个根节点,也就是多棵树;在连接关系中,除了可以使用列明外,还允许使用列表达式。
    START WITH 子句为可选项,用来标识哪个节点作为查找树形结构的根节点。若该子句省略,则表示所有满足查询条件的行作为根节点。
    条件2:是连接条件,其中用PRIOR表示上一条记录,例如CONNECT BY PRIOR STUDENT_ID = GRADE_ID,意思就是上一条记录的STUDENT_ID是本条记录
    的GRADE_ID,即本记录的父亲是上一条记录。CONNECT BY子句说明每行数据将是按照层次顺序检索,并规定将表中的数据连入树形结构的关系中。
    PRIOR运算符必须放置在连接关系的2列中某一个的前面。对于节点间的父子关系,PRIOR运算符在一侧表示父节点,在另一侧表示子节点,从而确定查
    找树结构的顺序是自顶向下,还是自底向上。
    条件3:是过滤条件,用于对返回的记录进行过滤。

    1,

    SELECT level, id FROM table
    WHERE id != 's111111' 
    START WITH id = 's111111' CONNECT BY id = PRIOR up_id

    查询出来的结果是id为s111111的所有父级数据

    2,

    SELECT level, id FROM table
    WHERE id != 's111111' 
    START WITH id = 's111111' CONNECT BY up_id = PRIOR id

    查询出来的结果是id为s111111的所有子级数据

  • 相关阅读:
    字符串-06. IP地址转换
    字符串-05. 字符串循环左移
    字符串-04. 字符串逆序
    BZOJ 3110
    UOJ 34 fft板子
    BZOJ 2716
    BZOJ 2243
    BZOJ 3697
    BZOJ 1176
    BZOJ 2599
  • 原文地址:https://www.cnblogs.com/cailijuan/p/13153702.html
Copyright © 2011-2022 走看看