Oracle 树形结构遍历代码讲解

-- 遍历SQL

  create table test (
   id  int ,
  pid int ,
  name varchar(10))

  insert into test values ( 1, 0 ,'n1' );

  insert into test values ( 2, 1 ,'n12' );

  insert into test values ( 3, 1 ,'n13' );

  insert into test values ( 4, 2 ,'n21' );

  insert into test values ( 5, 2 ,'n22' );

  insert into test values ( 6, 3 ,'n31' );

  insert into test values ( 7, 3 ,'n32' );

  insert into test values ( 8, 4 ,'n211' );

  insert into test values ( 9, 4 ,'n212' );

  //从叶结点开始找根节点

  // prior 关键字 与谁放在一起,就是找谁

  select * from test

  start with id=7

  connect by id = prior pid;

  // 从根结点开始找子节点

  select * from test

  start with id=2

  connect by prior id =  pid;

  //选择某层的下级节点

  // level 是oracle 保留的级数字段

  select id,name ,level from test

  where level <=2

  start with id =2

  connect by prior id =  pid;

 

 

 

-- 查出 7839 总裁下面各级 员工的工资和
 select level , sum(sal)
   from emp
 group by level
 start with empno = 7839
 connect by prior empno = mgr

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值