ORACLE递归查询语法
既然会看ORACLE递归查询那么大家应该是比较清楚递归是什么意思了,在这里我就不多加说明了,只作简单介绍了。
言归正传所谓递归查询那么数据表中数据的结构应该是符合递归查询的基本条件,即表中有ID,PID(节点编号、父节点编号)如果把数据以UI的方式展现出来应该是一棵或多棵树了。
那么我们要以其中一个节点去递归查询出这个节点子节点或父节点的过程就是我们所要说明的。
递归查询语法:
select ... from tablename where 条件4 start with 条件1 connect by 条件2 AND 条件3
|
如下面的表结构:
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的子节点(这点大家注意了),--当前也有过滤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
--总结:到底是查父节点还是子节点,有级联顺序决定
--规律:【本记录字段】=【连接字段】
--如本实例:是通过本记录的parentid匹配其他记录的aid(主键)结果是查父节点
--如顺序颠倒,则是:有本记录的aid(主键)匹配其他记录的parentid,结果是查子节点
--总结:start with ...connect by prior 递归查询也是对结果过滤,类似where过滤,先于where过滤执行
741

被折叠的 条评论
为什么被折叠?



