【Oracle】Oracle语法之递归查询

目录

  • 递归查询
  • 使用场景
    • 备注
  • 语法
    • 相关属性解释
  • 案例
    • 基本使用
    • 升级版-带上递归查询的属性
  • 总结:

递归查询

  • Oracle的递归查询是指在一个查询语句中使用自引用的方式进行循环迭代查询。
  • 它可以用于处理具有层次结构的数据,如组织架构、产品类别等。
  • 递归查询通常使用WITH子句来定义递归查询的起始条件和终止条件,并使用UNION ALL运算符来连接递归查询的结果。

使用场景

递归查询在以下场景中经常被使用:

  1. 组织架构查询:递归查询可以用于查找组织架构的层次结构,例如查询某个员工的上级、下属或者所有下属。

  2. 产品类别查询:递归查询可以用于查询产品类别的层次结构,例如查询某个类别的所有子类别或者找到某个产品所属的所有类别。

  3. 树状结构查询:递归查询可以用于查询树状结构的层次关系,例如查询文件系统的目录结构、查询城市的层级关系等。

  4. 图结构查询:递归查询可以用于查询图结构的相关信息,例如查询社交网络中某个人的朋友列表、查询电影的相关推荐等。

  5. 日期范围查询:递归查询可以用于查询一个连续的日期范围内的数据,例如查询某个日期范围内的销售数据或者某个日期范围内的日志信息。

备注

  • 需要注意的是,在使用递归查询时要注意性能问题,特别是当数据量较大时。
  • 为了避免性能问题,可以使用递归查询的剪枝功能、添加适当的索引或者使用其他优化技巧来提升查询效率。
  • 此外,对于复杂的递归查询,可能需要考虑使用存储过程或者递归SQL重写来优化查询性能。

语法

SELECT * FROM TABLE WHERE 条件3 START WITH 条件1 CONNECT BY 条件2;

相关属性解释

  • start with [condition]: 设置起点,用来限制第一层的数据,或者叫根节点数据;以这部分数据为基础来查找第二层数据,然后以第二层数据查找第三层数据以此类推。省略后默认以全部行为起点。

  • connect by [condition] : 用来指明在查找数据时以怎样的一种关系去查找;比如说查找第二层的数据时用第一层数据某个字段进行匹配,如果这个条件成立那么查找出来的数据就是第二层数据,同理往下递归匹配。

  • prior : 表示上一层级的标识符。经常用来对下一层级的数据进行限制。不可以接伪列。prior在等号前面和后面,查询的数据是不一样的

  • level : 伪列(关键字),代表树形结构中的层级编号(数字序列结果集),这个必须配合connect by使用,和rownum是同等效果。

  • connect_by_root : 显示根节点列。经常用来分组。

  • connect_by_isleaf : 1是叶子节点,0不是叶子节点。在制作树状表格时必用关键字。

  • sys_connect_by_path() : 将递归过程中的列进行拼接。

  • nocycle、connect_by_iscycle: 在有循环结构的查询中使用。

  • siblings : 保留树状结构,对兄弟节点进行排序。

案例

基本使用

假设我们要创建一个员工表,包含员工ID、姓名和上级ID字段。我们可以按照以下方式创建表结构并插入一些数据:

CREATE TABLE employees (employee_id NUMBER,name VARCHAR2(50),manager_id NUMBER
);INSERT INTO employees VALUES (1, 'Alice', NULL);
INSERT INTO employees VALUES (2, 'Bob', 1);
INSERT INTO employees VALUES (3, 'Charlie', 2);
INSERT INTO employees VALUES (4, 'Dave', 2);
INSERT INTO employees VALUES (5, 'Eve', 1);

现在我们可以编写两个递归查询,一个向上查找某个员工的所有上级,一个向下查找某个员工的所有下级。

向上递归查询可以使用CONNECT BY PRIOR关键字:

-- 向上递归查询
SELECT employee_id, name
FROM employees
START WITH name = 'Charlie' -- 起始条件
CONNECT BY PRIOR manager_id = employee_id -- 递归条件
ORDER BY level DESC;

结果将返回:

EMPLOYEE_ID | NAME
-----------------
1            Alice
2            Bob
3            Charlie

向下递归查询可以使用CONNECT BY关键字:

-- 向下递归查询
SELECT employee_id, name
FROM employees
START WITH name = 'Alice' -- 起始条件
CONNECT BY PRIOR employee_id = manager_id -- 递归条件
ORDER BY level;

结果将返回:

EMPLOYEE_ID | NAME
-----------------
1            Alice
2            Bob
3            Charlie
4            Dave
5            Eve

这样,我们就可以通过递归查询在员工表中向上或向下查找员工的上级或下级关系。

升级版-带上递归查询的属性

假设我们要创建一个部门表,包含部门ID、部门名称和上级部门ID字段。我们可以按照以下方式创建表结构并插入一些数据:

CREATE TABLE departments (department_id NUMBER,department_name VARCHAR2(50),parent_department_id NUMBER
);INSERT INTO departments VALUES (1, 'Sales', NULL);
INSERT INTO departments VALUES (2, 'Marketing', 1);
INSERT INTO departments VALUES (3, 'Finance', 1);
INSERT INTO departments VALUES (4, 'Operations', NULL);
INSERT INTO departments VALUES (5, 'Advertising', 2);

现在我们可以编写一个递归查询,查找某个部门的所有下级部门,并包含递归查询的属性。

-- 递归查询部门及其下级部门
SELECT CONNECT_BY_ROOT department_id AS root_department_id,d.department_id,d.department_name,d.parent_department_id,LEVEL
FROM departments d
START WITH department_id = 1 -- 起始条件
CONNECT BY PRIOR department_id = parent_department_id -- 递归条件
ORDER BY root_department_id, LEVEL;

结果将返回:

ROOT_DEPARTMENT_ID | DEPARTMENT_ID | DEPARTMENT_NAME | PARENT_DEPARTMENT_ID | LEVEL
-----------------------------------------------------------------------------------
1                   1               Sales             null                   1
1                   2               Marketing         1                      2
1                   5               Advertising       2                      3
1                   3               Finance           1                      2
4                   4               Operations        null                   1

在查询结果中,ROOT_DEPARTMENT_ID代表根部门的ID,DEPARTMENT_ID代表当前部门的ID,DEPARTMENT_NAME代表当前部门的名称,PARENT_DEPARTMENT_ID代表当前部门的上级部门ID,LEVEL代表当前部门在层级结构中的级别。

这样,我们可以通过递归查询在部门表中查找某个部门的所有下级部门,并获得相关属性的信息。

总结:

  • Oracle的递归查询是一种强大的功能,可以用于处理具有层次结构的数据(如组织架构、树形结构等)。
  • 递归查询基于CONNECT BY和PRIOR关键字,可以在SQL语句中实现递归的操作。

在使用Oracle的递归查询时,需要注意以下几点:

  1. 递归查询的起始条件:使用START WITH子句来指定递归查询的起始条件,即从哪个节点开始递归。
  2. 递归查询的递归条件:使用CONNECT BY PRIOR子句来指定递归查询的递归条件,即如何从一个节点递归到下一个节点。
  3. 递归查询的属性:在递归查询中,可以使用CONNECT_BY_ROOT关键字来获取根节点的属性,使用LEVEL关键字来获取当前节点在层次结构中的级别。
  4. 递归查询的排序:通过ORDER BY子句可以对递归查询的结果进行排序,可以按照根节点、级别等进行排序。
  5. 递归查询的限制:在处理大型数据集时,递归查询可能导致性能问题,可以通过设置递归查询的最大深度(MAXDEPTH)或者使用剪枝条件(PRUNE)来限制递归查询的范围。

递归查询在实际应用中有很多使用场景,例如处理组织架构、查找树形结构的子节点或父节点、获取层级结构的路径等。通过合理使用递归查询,可以简化复杂的数据处理操作,提高查询效率和代码的可读性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/872735.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【深度学习入门篇 ⑧】关于卷积神经网络

【🍊易编橙:一个帮助编程小伙伴少走弯路的终身成长社群🍊】 大家好,我是小森( ﹡ˆoˆ﹡ ) ! 易编橙终身成长社群创始团队嘉宾,橙似锦计划领衔成员、阿里云专家博主、腾讯云内容共创官…

Python和C++骨髓细胞进化解析数学模型

🎯要点 🎯 数学模型邻接矩阵及其相关的转移概率 | 🎯蒙特卡罗模拟进化动力学 | 🎯细胞进化交叉图族概率 | 🎯进化图模型及其数学因子 | 🎯混合图模式对进化概率的影响 | 🎯造血干细胞群体的空间…

汇总国内镜像提供了Redis的下载地址

文章目录 1. 清华大学开源软件镜像站:2. 中国科技大学开源软件镜像:3. 阿里云镜像:4. 华为云镜像:5. 腾讯云镜像:6. 网易开源镜像站7. 官方GitHub仓库(虽然不是镜像,但也是一个可靠的下载源&…

JAVA面试题--IO流

### IO流 #### 你知道BIO,NIO,AIO么?讲一下你的理解 BIO (Blocking I/O):同步阻塞I/O 模式,以流的方式处理数据,数据的读取写入必须阻塞在一个线程内等待其完成。适用于连接数目比较小且固定的架构 NIO…

AI算法19-偏最小二乘法回归算法Partial Least Squares Regression | PLS

偏最小二乘法回归算法简介 算法概述 偏最小二乘法模型可分为偏最小二乘回归模型和偏最小二乘路径模型。其中偏最小二乘回归模型是一种新型的多元统计方法,它集中了主成分分析、典型相关分析和线性回归的特点,特别在解决回归中的共线性问题具有无可比拟…

# Redis 入门到精通(五)-- redis 持久化(2)

Redis 入门到精通(五)-- redis 持久化(2) 一、redis 持久化–save 配置与工作原理 1、RDB 启动方式:反复执行保存指令,忘记了怎么办?不知道数据产生了多少变化,何时保存&#xff1…

深入解析JVM内存模型:面试题及详细解答

深入解析JVM内存模型:面试题及详细解答 1. JVM内存模型概述1.1 面试题:请简述JVM内存模型的组成部分及其作用。1.1.1 详细解答 2. 垃圾收集与内存分配2.1 面试题:对象在JVM中的内存分配过程是怎样的?2.1.1 详细解答 3. 垃圾收集器…

centos清空history

centos清空history history -c && history -w

CNN之图像识别

Inception Inception网络是CNN发展史上一个重要的里程碑。在Inception出现之前,大部分流行CNN仅仅是把卷积层堆叠得越来越多,使网络越来越深,以此希望能够得到更好的性能。但是存在以下问题: 图像中突出部分的大小差别很大。由于信息位置的…

同学,你会用ChatGPT吗?

ChatGPT在国外走红后,国内的讯飞星火、文心一言以及最近备受瞩目的Kimi等AI大模型也迅速崭露头角。这些技术突破不仅展现了我国在人工智能领域的实力,更预示着未来工作方式的深刻变革。随着人工智能大模型的普及和应用,它们将如同个人电脑一样…

【typedb】例子:药物发现: studio运行

测试8:solution结果 测试1:获取名字为Q9NPB9的protein Let’s start by getting the names of the protein Q9NPB9:测试2:哪个基因编码了Q9NPB9 Now let’s see which gene encodes for protein Q9NPB9: 推理过程:

【Linux】基础I/O——FILE,用户缓冲区

1.FILE里的fd FILE是C语言定义的文件结构体,里面包含了各种文件信息。可以肯定的一点是,FILE结构体内一定封装了 fd 。为什么?来看接下来的思路分析: 1.使用系统接口的必然性   文件存储在磁盘上,属于外设。谁有权限访问…

RabbitMQ:基础篇

1.RabbitMQ是高性能的异步通讯组件 何为异步通讯 打电话就是同步通讯,微信聊天可以理解为异步通讯,不是实时的进行通讯:时效性差。 同步调用的缺点: 拓展性差(需求不尽提) 性能下降 级联失败 …

Ubuntu的SELinux

Ubuntu的SELinux 安装的软件包:selinux-policy-targeted、libselinux-utils、 policycoreutils 命令行命令 以下默认root用户输入命令 确保在下次重启时重新标记文件,会在根目录创建.autorelabel文件 fixfiles -F onboot状态和模式 查看当前的 SELinu…

Percolator 事务模型的理解和梳理

Percolator 事务模型 Percolator 协议是一个 2PC 协议,TiDB 、 CockroachDB 等都使用 Percolator 协议来做事务 Percolator 协议把数据附加额外 2 个信息以及版本的概念 如下,一个数据 A ,类似以下方式表达: 版本datalockwrit…

Windows图形界面(GUI)-DLG-C/C++ - 静态控件(Static)

公开视频 -> 链接点击跳转公开课程博客首页 -> ​​​​​​链接点击跳转博客主页 目录 静态控件(Static) 控件样式 消息处理 实例代码 静态控件(Static) 控件样式 文本(Text):用来显示文本信息。可以是简单的一行文本或者复杂的…

带你轻松玩转DevOps

一、DevOps详细介绍 软件开发最开始是由两个团队组成: 开发计划由**开发团队**从头开始设计和整体系统的构建。需要系统不停的迭代更新。**运维团队**将开发团队的Code进行测试后部署上线。希望系统稳定安全运行。 这两个看似目标不同的团队,需要协同完…

HarmonyOS 开发者联盟高级认证最新题库

本篇文章包含 Next 版本更新后高级认证题库中95%的题目。 答案正确率 50-60%,答案仅做参考。 请在考试前重点看一遍题目,勿要盲目抄答案。 欢迎在评论留言正确答案和未整理的题目。 1、下面关于方舟字节码格式PREF_IMM16_v8_v8描述正确的是 16位前缀操作…

dp or 数学问题

看一下数据量&#xff0c;只有一千&#xff0c;说明这个不是数学问题 #include<bits/stdc.h> using namespace std;#define int long long const int mo 100000007; int n, s, a, b; const int N 1005;// 2 -3 // 1 3 5 2 -1 // 1 -2 -5 -3 -1 int dp[N][N]; int fun…

算法力扣刷题记录 四十九【112. 路径总和】和【113. 路径总和ii】

前言 二叉树篇继续。 记录 四十九【112. 路径总和】和【113. 路径总和ii】 一、【112. 路径总和】题目阅读 给你二叉树的根节点 root 和一个表示目标和的整数 targetSum 。判断该树中是否存在 根节点到叶子节点 的路径&#xff0c;这条路径上所有节点值相加等于目标和 target…