oracle 递归查询 CONNECT BY、START WITH、CONNECT_BY_ROOT、CONNECT_BY_ISLEAF、SYS_CONNECT_BY_PATH

创建表,初始化数据;

[sql]  view plain  copy
  1. CREATE TABLE TB_COMPANY  
  2. (  
  3.   COMPANY_ID INTEGER PRIMARY KEY,  
  4.   COMPANY VARCHAR2(256),  
  5.   UP_COMPANYID INTEGER  
  6. );  
  7.   
  8. INSERT INTO TB_COMPANY VALUES (0, '总公司'NULL);  
  9. INSERT INTO TB_COMPANY VALUES (1, '北京分公司', 0);  
  10. INSERT INTO TB_COMPANY VALUES (2, '上海分公司', 0);  
  11. INSERT INTO TB_COMPANY VALUES (3, '海淀区分部', 1);  
  12. INSERT INTO TB_COMPANY VALUES (4, '东城区分部', 1);  
  13. INSERT INTO TB_COMPANY VALUES (5, '黄埔区分部', 2);  
  14. INSERT INTO TB_COMPANY VALUES (6, '静安区分部', 2);  
  15. COMMIT;  

全部数据:



递归查询SQL:

[sql]  view plain  copy
  1. SELECT (RPAD(' ', 2*(LEVEL-1), '-' ) || COMPANY) COMPANY_NAME, CONNECT_BY_ROOT COMPANY, CONNECT_BY_ISLEAF, LEVEL , SYS_CONNECT_BY_PATH(COMPANY, '/')  
  2. FROM TB_COMPANY  
  3. START WITH UP_COMPANYID IS NULL  
  4. CONNECT BY PRIOR COMPANY_ID = UP_COMPANYID;  

结果:



说明:

1. CONNECT_BY_ROOT 返回当前节点的最顶端节点 
2. CONNECT_BY_ISLEAF 判断是否为叶子节点,如果这个节点下面有子节点,则不为叶子节点 
3. LEVEL 伪列表示节点深度 
4. SYS_CONNECT_BY_PATH函数显示详细路径,并用“/”分隔


递归查询SQL:

[sql]  view plain  copy
  1. SELECT * FROM TB_COMPANY START WITH COMPANY_ID = 1 CONNECT BY PRIOR COMPANY_ID = UP_COMPANYID;  

结果:


  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值