Oracle递归查询
发表于:2025-01-21 作者:千家信息网编辑
千家信息网最后更新 2025年01月21日,----创建数据1.1、建立表与插入数据CREATE TABLE DISTRICT( ID NUMBER(10) NOT NULL, PARENT
千家信息网最后更新 2025年01月21日Oracle递归查询
----创建数据
1.1、建立表与插入数据
CREATE TABLE DISTRICT( ID NUMBER(10) NOT NULL, PARENT_ID NUMBER(10), NAME VARCHAR2(255 BYTE) NOT NULL);ALTER TABLE DISTRICT ADD ( CONSTRAINT DISTRICT_PK PRIMARY KEY (ID));ALTER TABLE DISTRICT ADD ( CONSTRAINT DISTRICT_R01 FOREIGN KEY (PARENT_ID) REFERENCES DISTRICT (ID)); insert into DISTRICT (id, parent_id, name)values (1, null, '四川省');insert into DISTRICT (id, parent_id, name)values (2, 1, '巴中市');insert into DISTRICT (id, parent_id, name)values (3, 1, '达州市');insert into DISTRICT (id, parent_id, name)values (4, 2, '巴州区');insert into DISTRICT (id, parent_id, name)values (5, 2, '通江县');insert into DISTRICT (id, parent_id, name)values (6, 2, '平昌县');insert into DISTRICT (id, parent_id, name)values (7, 3, '通川区');insert into DISTRICT (id, parent_id, name)values (8, 3, '宣汉县');insert into DISTRICT (id, parent_id, name)values (9, 8, '塔河乡');insert into DISTRICT (id, parent_id, name)values (10, 8, '三河乡');insert into DISTRICT (id, parent_id, name)values (11, 8, '胡家镇');insert into DISTRICT (id, parent_id, name)values (12, 8, '南坝镇');insert into DISTRICT (id, parent_id, name)values (13, 6, '大寨乡');insert into DISTRICT (id, parent_id, name)values (14, 6, '响滩镇');insert into DISTRICT (id, parent_id, name)values (15, 6, '龙岗镇');insert into DISTRICT (id, parent_id, name)values (16, 6, '白衣镇');commit;
二、start with connect by prior递归
查询所有子节点
SELECT *
FROM district
START WITH NAME ='巴中市'
CONNECT BY PRIOR ID=parent_id
2.2、查询所有父节点
SELECT *
FROM district
START WITH NAME ='平昌县'
CONNECT BY PRIOR parent_id=ID
只需要交换 id 与parent_id的位置即可
2.3、查询指定节点的,根节点
SELECT d.*,connect_by_root(d.id),connect_by_root(NAME)FROM district dWHERE NAME='平昌县'START WITH d.parent_id=1 --d.parent_id is null 结果为四川省CONNECT BY PRIOR d.ID=d.parent_id
2.4、查询巴中市下行政组织递归路径
SELECT ID,parent_id,NAME,sys_connect_by_path(NAME,'->') namepath,LEVELFROM district START WITH NAME='巴中市'CONNECT BY PRIOR ID=parent_id
三、with递归
3.1、with递归子类
WITH t (ID ,parent_id,NAME) --要有列名AS(SELECT ID ,parent_id,NAME FROM district WHERE NAME='巴中市'UNION ALLSELECT d.ID ,d.parent_id,d.NAME FROM t,district d --要指定表和列表,WHERE t.id=d.parent_id)SELECT * FROM t;
3.2、递归父类
WITH t (ID ,parent_id,NAME) --要有表AS(SELECT ID ,parent_id,NAME FROM district WHERE NAME='通江县'UNION ALLSELECT d.ID ,d.parent_id,d.NAME FROM t,district d --要指定表和列表,WHERE t.parent_id=d.id)SELECT * FROM t;
递归
巴中
巴中市
查询
节点
平昌
平昌县
数据
通江
四川
四川省
通江县
位置
大寨
子类
白衣
结果
路径
宣汉
通川
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
ibm服务器ghost
浙江专业软件开发靠谱吗
深圳数英程软件开发有限公司
网络技术单招院校
衡水市委网络安全和信息化
文辉软件开发有限公司
网络安全与执法选修课
无线网络技术导论论文方向
天津行业软件开发公司
网络安全三重防护
软件开发员的发展
网狐数据库怎么支持小数
网络安全法 专线
防疫大数据库可以查到多久的
学习软件开发需要什么基础吗
数据库对ip有限制
查看所有的数据库的代码
数据库io是网络io吗
我的世界遗忘之海手机版服务器
金三税系统服务器地址
苹果服务器为什么会出错
邯郸盛邦软件开发有限公司
查找数据库中的数据类型
网络安全人才培训规划
服务器国家怎么管理
南京物流软件开发平台
什么是数据库dba权限
广播电视网络安全 重要性
数据库逻辑设计阶段不必转换
逃离塔科夫法国服务器怎么样