ORACLE 递归查询

系统 1694 0

既然会看ORACLE递归查询那么大家应该是比较清楚递归是什么意思了,在这里我就不多加说明了,只作简单介绍了。

言归正传所谓递归查询那么数据表中数据的结构应该是符合递归查询的基本条件,即表中有ID,PID(节点编号、父节点编号)如果把数据以UI的方式展现出来应该是一棵或多棵树了。

那么我们要以其中一个节点去递归查询出这个节点子节点或父节点的过程就是我们所要说明的。

递归查询语法:

 

select ... from tablename  where 条件4 start with 条件1  connect by 条件2 AND 条件3

 

如下面的表结构 http://www.cnblogs.com/wanghonghu/archive/2012/08/31/2665945.html

    
      CREATE
    
    
      TABLE
    
    
       SC_DISTRICT

(

  IID         
    
    
      NUMBER
    
    (
    
      10
    
    )                  
    
      NOT
    
    
      NULL
    
    
      ,

  PARENT_ID  
    
    
      NUMBER
    
    (
    
      10
    
    
      ),

  INAME       
    
    
      VARCHAR2
    
    (
    
      255
    
     BYTE)          
    
      NOT
    
    
      NULL,
    
    
      

 BZ      
      
        NUMBER
      
      (
      
        4
      
      )
      
);
ALTER TABLE SC_DISTRICT ADD ( CONSTRAINT SC_DISTRICT_PK PRIMARY KEY (IID)); ALTER TABLE SC_DISTRICT ADD ( CONSTRAINT SC_DISTRICT_R01 FOREIGN KEY (PARENT_ID) REFERENCES SC_DISTRICT (IID));
    
      INSERT
    
    
      INTO
    
     SC_DISTRICT(IID,INAME) 
    
      VALUES
    
    (
    
      1
    
    ,
    
      '
    
    
      四川省
    
    
      '
    
    
      );




    
    
      INSERT
    
    
      INTO
    
     SC_DISTRICT(IID,PARENT_ID,INAME,BZ) 
    
      VALUES
    
    (
    
      2
    
    ,
    
      1
    
    ,
    
      '
    
    
      巴中市
    
    
      ',0
    
    
      );


    
    
      INSERT
    
    
      INTO
    
     SC_DISTRICT(IID,PARENT_ID,INAME,BZ) 
    
      VALUES
    
    (
    
      3
    
    ,
    
      1
    
    ,
    
      '
    
    
      达州市
    
    
      ',0
    
    
      ); 




    
    
      INSERT
    
    
      INTO
    
     SC_DISTRICT(IID,PARENT_ID,INAME,BZ) 
    
      VALUES
    
    (
    
      4
    
    ,
    
      2
    
    ,
    
      '
    
    
      巴州区
    
    
      ',0
    
    
      );


    
    
      INSERT
    
    
      INTO
    
     SC_DISTRICT(IID,PARENT_ID,INAME,BZ) 
    
      VALUES
    
    (
    
      5
    
    ,
    
      2
    
    ,
    
      '
    
    
      通江县
    
    
      ',0
    
    
      );


    
    
      INSERT
    
    
      INTO
    
     SC_DISTRICT(IID,PARENT_ID,INAME,BZ) 
    
      VALUES
    
    (
    
      6
    
    ,
    
      2
    
    ,
    
      '
    
    
      平昌县
    
    
      ',0
    
    
      );




    
    
      INSERT
    
    
      INTO
    
     SC_DISTRICT(IID,PARENT_ID,INAME,BZ) 
    
      VALUES
    
    (
    
      7
    
    ,
    
      3
    
    ,
    
      '
    
    
      通川区
    
    
      ',0
    
    
      );


    
    
      INSERT
    
    
      INTO
    
     SC_DISTRICT(IID,PARENT_ID,INAME,BZ) 
    
      VALUES
    
    (
    
      8
    
    ,
    
      3
    
    ,
    
      '
    
    
      宣汉县
    
    
      ',0
    
    
      );




    
    
      INSERT
    
    
      INTO
    
     SC_DISTRICT(IID,PARENT_ID,INAME,BZ) 
    
      VALUES
    
    (
    
      9
    
    ,
    
      8
    
    ,
    
      '
    
    
      塔河乡
    
    
      ',1
    
    
      );


    
    
      INSERT
    
    
      INTO
    
     SC_DISTRICT(IID,PARENT_ID,INAME,BZ) 
    
      VALUES
    
    (
    
      10
    
    ,
    
      8
    
    ,
    
      '
    
    
      三河乡
    
    
      ',1
    
    
      );


    
    
      INSERT
    
    
      INTO
    
     SC_DISTRICT(IID,PARENT_ID,INAME,BZ) 
    
      VALUES
    
    (
    
      11
    
    ,
    
      8
    
    ,
    
      '
    
    
      胡家镇
    
    
      ',1
    
    
      );


    
    
      INSERT
    
    
      INTO
    
     SC_DISTRICT(IID,PARENT_ID,INAME,BZ) 
    
      VALUES
    
    (
    
      12
    
    ,
    
      8
    
    ,
    
      '
    
    
      南坝镇
    
    
      ',1
    
    
      );

 


    
    
      INSERT
    
    
      INTO
    
     SC_DISTRICT(IID,PARENT_ID,INAME,BZ) 
    
      VALUES
    
    (
    
      13
    
    ,
    
      6
    
    ,
    
      '
    
    
      大寨乡
    
    
      ',2
    
    
      );


    
    
      INSERT
    
    
      INTO
    
     SC_DISTRICT(IID,PARENT_ID,INAME,BZ) 
    
      VALUES
    
    (
    
      14
    
    ,
    
      6
    
    ,
    
      '
    
    
      响滩镇
    
    
      ',2
    
    
      );


    
    
      INSERT
    
    
      INTO
    
     SC_DISTRICT(IID,PARENT_ID,INAME,BZ) 
    
      VALUES
    
    (
    
      15
    
    ,
    
      6
    
    ,
    
      '
    
    
      龙岗镇
    
    
      ',2
    
    
      );


    
    
      INSERT
    
    
      INTO
    
     SC_DISTRICT(IID,PARENT_ID,INAME,BZ) 
    
      VALUES
    
    (
    
      16
    
    ,
    
      6
    
    ,
    
      '
    
    
      白衣镇
    
    
      ',2
    
    );
    

如果如图

  ORACLE 递归查询

--查询平昌县的子节点

SELECT * FROM SC_DISTRICT
START WITH INAME = '平昌县'
CONNECT BY PRIOR IID = PARENT_ID

--查询平昌县的父节点

SELECT * FROM SC_DISTRICT
START WITH INAME = '平昌县'
CONNECT BY PRIOR  PARENT_ID= IID

--只是查询当前节点BZ为0的,但不会查询节点BZ为0的子节点(这点大家注意了)

SELECT * FROM SC_DISTRICT
START WITH INAME = '平昌县' AND BZ = 0
CONNECT BY PRIOR  PARENT_ID= IID ;

--查询当前节点和子节点的BZ为0的方法

SELECT * FROM SC_DISTRICT WHERE BZ = 0
START WITH INAME = '平昌县'
CONNECT BY PRIOR PARENT_ID= IID

--此方式不仅可以查询BZ为0的节点而且会不再去遍历此节点的子节点

SELECT * FROM SC_DISTRICT START WITH INAME = '平昌县'
CONNECT BY PRIOR PARENT_ID= IID AND BZ = 0

如果大家对递归的方式比较了解的话上面的几种方式就很容易理解了。

ORACLE 递归查询


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论