Oracle中递归查询(START WITH……CONNECT BY……)

一、基本语法

OracleSTART WITH......CONNECT BY......一般用来查找存在父子关系的数据,也就是树形结构的数据。

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() :将递归过程中的列进行拼接。

  • nocycleconnect_by_iscycle:在有循环结构的查询中使用。

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

二、数据列表展示

2.1 向下查找

查询以organ_id为2开始的节点的所有直属节点:

sql 复制代码
select t.organ_id, t.parent_id, t.organ_abbr,level
  from tem_organ_0619 t
 start with t.organ_id = 2
connect by prior t.organ_id = t.parent_id
  order by t.organ_id;

不设置开始节点:

sql 复制代码
select t.organ_id, t.parent_id, t.organ_abbr,level
  from tem_organ_0619 t
 -- start with t.organ_id = 2
connect by prior t.organ_id = t.parent_id
  order by t.organ_id;

2.2 向上查找

sql 复制代码
select t.organ_id, t.parent_id, t.organ_abbr,level
  from tem_organ_0619 t
 start with t.organ_id = 20401
connect by  t.organ_id = prior t.parent_id
  order by t.organ_id;

2.3 level伪列的使用,格式化层级

sql 复制代码
select t.organ_id, t.parent_id, lpad(' ',level*4,' ')||t.organ_abbr organ_abbr,level
  from tem_organ_0619 t
 start with t.organ_id = 2
connect by  t.organ_id = prior t.parent_id
  order by t.organ_id;

2.4 connect_by_root查找根节点

sql 复制代码
select t.organ_id, 
       t.parent_id, 
       lpad(' ',level*4,' ')||t.organ_abbr organ_abbr,
       level ,
       connect_by_root t.organ_id
  from tem_organ_0619 t
 start with t.organ_id = 2
connect by  t.organ_id = prior t.parent_id
  order by t.organ_id;

2.5 connect_by_isleaf是否是叶子节点

sql 复制代码
select t.organ_id, 
       t.parent_id, 
       lpad(' ',level*4,' ')||t.organ_abbr organ_abbr,
       level ,
       connect_by_root t.organ_id, 
       connect_by_isleaf
  from tem_organ_0619 t
 start with t.organ_id = 2
connect by  t.organ_id = prior t.parent_id
  order by t.organ_id;

2.6 其他

sql 复制代码
select t.organ_id, 
	   t.parent_id, 
	   lpad(' ',level*4,' ')||t.organ_abbr organ_abbr,
	   level 层级,
	   sys_connect_by_path(t.organ_id, '<-') 合并层次,
	   PRIOR t.organ_id 父节点, 
	   connect_by_root t.organ_id 根节点, 
	   decode(connect_by_isleaf, 1, '是', '否') 是否子节点, 
	   decode(connect_by_isleaf, 1, t.organ_id, '') 子节点
  from tem_organ_0619 t
 start with t.organ_id = 2
connect by  t.organ_id = prior t.parent_id
  order by t.organ_id;
相关推荐
JdSnE27zv11 小时前
SQLite内存数据库
数据库·sql·sqlite
SelectDB技术团队11 小时前
预约发布会|核心产品力首发,如何构建面向 Agent 时代的企业级数据引擎
数据库·数据仓库·人工智能·数据分析·可观测·apache doris·selectdb
2601_9618451511 小时前
2026四级作文预测题|英语四级写作押题+提纲PDF
java·c语言·数据库·c++·python·pdf·php
计算机安禾11 小时前
【数据库系统原理】第13篇:现实世界的概念抽象:实体-联系模型向关系模型的转化策略
数据库
JAVA面经实录91711 小时前
NoSQL 非关系型数据库【简洁版】
java·数据库·nosql
IvorySQL11 小时前
PostgreSQL 19 新特性:基于 SQL/PGQ 实现图数据查询
数据库·sql·postgresql
jghhh0111 小时前
C# 图片水印工具(支持9个位置)
数据库·microsoft·c#
辰海Coding12 小时前
MiniSpring框架学习笔记-JDBC 访问框架:如何抽取 JDBC 模板并隔离数据库?
java·数据库·笔记·学习·spring
救救孩子把12 小时前
01 Milvus-向量数据库基础
数据库·milvus
闪电悠米12 小时前
黑马点评-Redis 消息队列-01_why_redis_mq
java·数据库·spring boot·redis·缓存·junit·消息队列