Oracle递归查询层级及路径

一、建表及插入数据

ocation_id location_name parent_location_id
1 广东省 NULL
2 广州市 1
3 深圳市 1
4 天河区 2
5 番禺区 2
6 南山区 3
7 宝安区 3

建表sql:

sql 复制代码
CREATE TABLE locations (
    location_id NUMBER PRIMARY KEY,
    location_name VARCHAR2(100),
    parent_location_id NUMBER
);
INSERT INTO locations (location_id, location_name, parent_location_id)
VALUES (1, '广东省', NULL);

INSERT INTO locations (location_id, location_name, parent_location_id)
VALUES (2, '广州市', 1);

INSERT INTO locations (location_id, location_name, parent_location_id)
VALUES (3, '深圳市', 1);

INSERT INTO locations (location_id, location_name, parent_location_id)
VALUES (4, '天河区', 2);

INSERT INTO locations (location_id, location_name, parent_location_id)
VALUES (5, '番禺区', 2);

INSERT INTO locations (location_id, location_name, parent_location_id)
VALUES (6, '南山区', 3);

INSERT INTO locations (location_id, location_name, parent_location_id)
VALUES (7, '宝安区', 3);

二、展现出省市县之间的层级结构

sql:

sql 复制代码
SELECT location_id, location_name, LEVEL
FROM locations
CONNECT BY PRIOR location_id = parent_location_id
START WITH parent_location_id IS NULL;

结果:

location_id location_name LEVEL
1 广东省 1
2 广州市 2
4 天河区 3
5 番禺区 3
3 深圳市 2
6 南山区 3
7 宝安区 3

三、每个区域在层级结构中的完整路径

sql:

sql 复制代码
SELECT location_id, 
       location_name, 
       LEVEL, 
       SYS_CONNECT_BY_PATH(location_name,'/') AS path
FROM locations
CONNECT BY PRIOR location_id = parent_location_id
START WITH parent_location_id IS NULL;

结果:

location_id location_name LEVEL path
1 广东省 1 广东省
2 广州市 2 广东省/广州市
4 天河区 3 广东省/广州市/天河区
5 番禺区 3 广东省/广州市/番禺区
3 深圳市 2 广东省/深圳市
6 南山区 3 广东省/深圳市/南山区
7 宝安区 3 广东省/深圳市/宝安区
相关推荐
一只淡水鱼6615 分钟前
【mybatis】基本操作:详解Spring通过注解和XML的方式来操作mybatis
java·数据库·spring·mybatis
张声录117 分钟前
【ETCD】【实操篇(十六)】基于角色的访问控制:ETCD 安全管理指南
数据库·安全·etcd
warrah23 分钟前
redis——岁月云实战
数据库·redis·缓存
秀儿y24 分钟前
Redis-十大数据类型
数据库·redis·缓存·oracle
凡人的AI工具箱44 分钟前
每天40分玩转Django:Django类视图
数据库·人工智能·后端·python·django·sqlite
路在脚下@1 小时前
MySQL的索引失效的原因有那些
数据库·mysql
凡人的AI工具箱1 小时前
每天40分玩转Django:实操图片分享社区
数据库·人工智能·后端·python·django
CT随1 小时前
MongoDB
数据库·mongodb
Fool丶玄浅2 小时前
【数据库系统概论】—— 关系数据库
数据库·数据库系统
DashVector2 小时前
如何通过HTTP API检索Doc
数据库·人工智能·http·阿里云·数据库开发·向量检索