我的编程空间,编程开发者的网络收藏夹
学习永远不晚

一文解析ORACLE树结构查询

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

一文解析ORACLE树结构查询

我们在日常程序设计中,经常会遇到树状结构的表示,例如组织机构、行政区划等等。这些在数据库中往往通过一张表进行展示。这里我们以一张简单的行政区划表为例进行展示,在实际使用过程中,可以为其添加其他描述字段以及层级。

一文解析ORACLE树结构查询

表中通过ID和PID关联,实现树状结构的存储。建表以及数据语句如下:

-- Create table
create table TREETEST
(
  id   NVARCHAR2(50),
  pid  NVARCHAR2(50),
  name NVARCHAR2(50)
)
insert into TREETEST (ID, PID, NAME) values ('1', null, '山东省');
insert into TREETEST (ID, PID, NAME) values ('2', '1', '青岛市');
insert into TREETEST (ID, PID, NAME) values ('3', '1', '烟台市');
insert into TREETEST (ID, PID, NAME) values ('4', null, '河南省');
insert into TREETEST (ID, PID, NAME) values ('5', null, '河北省');
insert into TREETEST (ID, PID, NAME) values ('6', '2', '市南区');
insert into TREETEST (ID, PID, NAME) values ('7', '2', '市北区');
insert into TREETEST (ID, PID, NAME) values ('8', '2', '即墨市');

那对于树状结构如何查询呢?oracle提供递归查询的方式进行查询,基本语法如下:

SELECT [Column]…..
  FEOM [Table]
  WHERE Conditional1
  START WITH Conditional2
  CONNECT BY PRIOR Conditional3
  ORDER BY [Column]

说明:

  • 条件1---过滤条件,对全部返回的记录进行过滤。
  • 条件2---根节点的限定条件,固然也可以放宽权限得到多个根节点,也就是获取多个树
  • 条件3---链接条件,目的就是给出父子之间的关系是什么,根据这个关系进行递归查询(在上述表中就是ID=PID)
  • 排序---对全部返回记录进行排序

下面我们结合具体实例来看:

1、查询山东省下面的所有子节点

SELECT *
  FROM TREETEST t
 START WITH t.PID=1
CONNECT BY PRIOR t.ID = t.PID

其中ID为1的为山东省节点,查询结果如下:

一文解析ORACLE树结构查询

2、查询青岛市的下一级子节点(注意和上面区分,全部子节点和下一级子节点)

image

3、如果需要获取将山东省青岛市等连接起来显示,可以使用SYS_CONNECT_BY_PATH来实现

SELECT t.ID, SYS_CONNECT_BY_PATH(t.NAME, '\') AS INDU_NAME
  FROM TREETEST t
 START WITH t.PID IS NULL
CONNECT BY PRIOR t.ID = t.PID

查询结果如下:

一文解析ORACLE树结构查询

4、同理,也可以从下往上进行查询

SELECT *
  FROM TREETEST t
 START WITH t.ID=8
CONNECT BY t.ID = PRIOR t.PID

一文解析ORACLE树结构查询

到此这篇关于一文解析ORACLE树结构查询的文章就介绍到这了,更多相关ORACLE树结构查询内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

一文解析ORACLE树结构查询

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL树状结构表查询通解

文章目录 前言一、数据准备二、代码实现三、案例使用1. 建立数据表实体类2. mapper文件3. 使用 四、总结 前言 ​ 最近做了一个中医药方面的项目,该项目分为游戏端和服务端。笔者负责的是服务端的开发。在服务端的业务中
2023-08-19

mysql的树形结构存储及查询实例分析

这篇文章主要介绍“mysql的树形结构存储及查询实例分析”,在日常操作中,相信很多人在mysql的树形结构存储及查询实例分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mysql的树形结构存储及查询实例分析
2023-06-29

openGemini之查询索引结构解析

Gemini是一个开源的搜索引擎项目,它提供了一个查询索引结构,用于快速检索和提取文档数据。下面是对Gemini查询索引结构进行解析的概述:1. 倒排索引(Inverted Index):Gemini使用倒排索引来加速数据的检索。倒排索引是
2023-09-13

构建一个 golang 结构来存储解析后的 JSON 文件中的数据

“纵有疾风来,人生不言弃”,这句话送给正在学习Golang的朋友们,也希望在阅读本文《构建一个 golang 结构来存储解析后的 JSON 文件中的数据》后,能够真的帮助到大家。我也会在后续的文章中,陆续更新Golang相关的技术文章,有好
构建一个 golang 结构来存储解析后的 JSON 文件中的数据
2024-04-05

浅析DedeCMS GBK版安装sphinx全文索引无法查询无结果的解决方法

本测试安装的是sphinx中文版-coreseek 4.0版,用测试中文的命令在命令行查询: echo 网络搜索 | iconv -f gbk -t utf-8 | search -c D:\webserver\coreseek-4.0.1
2022-06-12

编程热搜

目录