SELECT*FROM priortest
startwith id =1000connectby prior id = fatherid;--可以取到从这个id开始递归到的所有数据SELECT*FROM priortest
startwith id =1000connectby id = prior fatherid;--仅能取到最顶层数据SELECT*FROM priortest
startwith id =1000connectby prior fatherid = id;--仅能取到最顶层数据SELECT*FROM priortest
startwith fatherid =1000connectby prior id = fatherid;--除了顶层数据取不到SELECT*FROM priortest
startwith fatherid =1000connectby prior fatherid = id;--会取到重复数据
基本语法
SELECT ... FROM + 表名
START WITH + 条件1
CONNECT BY PRIOR + 条件2
WHERE + 条件3
CONNECT BY PRIOR是结构化查询中用到的;
START WITH… CONNECT BY PRIOR…的作用,简单来说,就是将一个树状结构存储在一张表里。
条件1:是根节点的限定语句,当然可以放宽限定条件,以取得多个根节点,也就是多棵树;在连接关系中,除了可以使用列名外,还允许使用列表达式。
START WITH 子句为可选项,用来标识哪个节点作为查找树形结构的根节点。若该子句省略,则表示所有满足查询条件的行作为根节点。
条件2:是连接条件,其中用PRIOR表示上一条记录,例如connect by prior id = fatherid,意思就是上一条记录的id是本条记录
的fatherid,即本记录的父亲是上一条记录。CONNECT BY子句说明每行数据将是按照层次顺序检索,并规定将表中的数据连入树形结构的关系中。
PRIOR运算符必须放置在连接关系的2列中某一个的前面。对于节点间的父子关系,PRIOR运算符在一侧表示父节点,在另一侧表示子节点,从而确定查
找树结构的顺序是自顶向下,还是自底向上。
条件3:是过滤条件,用于对返回的记录进行过滤。