oracle 逆向递归查询_ORACLE 递归查询

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

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

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

递归查询语法:

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

CREATE TABLESC_DISTRICT

(

IIDNUMBER(10) NOT NULL,

PARENT_IDNUMBER(10),

INAMEVARCHAR2(255 BYTE) NOT NULL,BZ      NUMBER(4)

);ALTER TABLE SC_DISTRICT ADD(CONSTRAINTSC_DISTRICT_PKPRIMARY KEY(IID));ALTER TABLE SC_DISTRICT ADD(CONSTRAINTSC_DISTRICT_R01FOREIGN 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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值