• ORACLE 递归查询


    既然会看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);

    如果如图

     

    --查询平昌县的子节点

    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

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

  • 相关阅读:
    sql基本语法:
    mysqldump: Couldn't execute 'SET OPTION SQL_QUOTE_SHOW_CREATE=1': You have an error in your SQL syntax; check the manual t
    truncate和 delete的区别:
    主流存储引擎详解:Innodb,Tokudb、Memory、MYISAM、Federated
    ant-design-vue表单生成组件form-create快速上手
    vue自定义表单生成器,可根据json参数动态生成表单
    Vue数据驱动表单渲染,轻松搞定form表单
    PHP表单生成器,快速生成现代化的form表单,快速上手
    form-create 组件生成规则说明
    form-create教程:自定义布局,实现一行多个组件
  • 原文地址:https://www.cnblogs.com/bpdwn/p/3125987.html
Copyright © 2020-2023  润新知