SQL语句实现递归查询

Wesley13
• 阅读 507

    最近在开发过程为项目中处理上下层组织关系的时候用到了递归查询,以前一般用的是直接在java中使用递归或者使用SQL的话就是编写存储过程,然后去调用这个存储过程。但是,使用java实现递归的话感觉比较麻烦,而用SQL写存储过程的话一般不建议这么做,所以这边就想到了直接用SQL实现递归。

    这里实现递归的是系统中的一个中间关系表(ORG_TABLE),表结构也比较简单,主要就是两个字段如下图所示ORG_ID_PARENT(上级组织机构ID)和ORG_ID_OWN(自身组织机构ID),这个比较重要一定要记住,我们在后面会有提及,此外还有一个组织机构的表这里就不讨论了,我们这里只讨论通过一个组织机构的ID获取它的所有上级组织的ID和它的所有子组织机构ID。

SQL语句实现递归查询

START WITH ... CONNECT BY PRIOR ....

我们一般使用SQL做递归的情况下用的都是上面一条语句,START WITH后面跟的是递归开始的数据,CONNECT BY后面跟的是递归的条件,PRIOR后面是递归的方向。

--查询所有子组织,父组织(包括自身)
SELECT * FROM ORG_TABLE START WITH ORG_ID_PARENT='16179968862193665' CONNECT BY  ORG_ID_PARENT = PRIOR ORG_ID_OWN    --查询所有子组织
union
SELECT * FROM ORG_TABLE START WITH ORG_ID_OWN='16179968862193665' CONNECT BY  PRIOR ORG_ID_PARENT = ORG_ID_OWN    --查询所有父组织(包括自身)

如上代码    第一条是查询出来改组织的所有下级组织,第二条数据是查出了所有组织的上级组织(包括自身)。我们这里来解析一下这写SQL的含义(16179968862193665为机构自身的ID):

    1,SELECT * FROM ORG_TABLE在这里就不多做解释了,这里注意一点,我们可以把我们的WHERE条件加在后面来筛选数据。

    2,START WITH ORG_ID_PARENT='16179968862193665'就是代表数据从ORG_ID_PARENT='16179968862193665'数据开始递归,先找出所有上级组织机构为'16179968862193665'的组织,这里我们可以用等号来设定一条数据,也可以用IN来设定一批数据。

    3,CONNECT BY个人感觉这里就相当于WHERE的意思。

    4,PRIOR在这里比较重要(注意:它放在等号之前或者之后无所谓),它代表将要递归的方向。如上代码向子组织递归,那么ORG_ID_PARENT = PRIOR ORG_ID_OWN的意思就是根据前面开始获取的那些ID开始递归,把最新获取的ID当做父组织ID,然后查找对应的子组织ID。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
待兔 待兔
3个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Irene181 Irene181
3年前
一篇文章带你了解Python递归函数
一、什么是递归函数?在函数内部,可以调用其他函数。如果一个函数在内部调用自身本身,这个函数就是递归函数。二、函数的递归调用原理实际上递归函数是在栈内存上递归执行的,每次递归执行一次就会耗费一些栈内存。栈内存的大小是限制递归深度的重要因素三、案例分析1.求阶乘计算阶乘n!1x2x3x…xn,可以用
Stella981 Stella981
3年前
SQL Server递归查询在Highgo DB中实现 (APP)
目录环境文档用途详细信息环境系统平台:MicrosoftWindows(64bit)10版本:5.6.4文档用途在HighgoDB中实现和SQLServer一样效果的递归查询详细信息1、SQLServer表创建以及测试数据添加CreatetableGroupInfo(\Id\int,\
Easter79 Easter79
3年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Easter79 Easter79
3年前
SQL Server递归查询在Highgo DB中实现 (APP)
目录环境文档用途详细信息环境系统平台:MicrosoftWindows(64bit)10版本:5.6.4文档用途在HighgoDB中实现和SQLServer一样效果的递归查询详细信息1、SQLServer表创建以及测试数据添加CreatetableGroupInfo(\Id\int,\
Stella981 Stella981
3年前
PostgreSQL的递归查询(with recursive)
开发有需求,说需要对一张地区表进行递归查询,Postgres中有个withrecursive的查询方式,可以满足递归查询(一般2层)。测试如下:createtabletb(idvarchar(3),pidvarchar(3),namevarchar(10));insertintotb
Wesley13 Wesley13
3年前
JAVA学习入门篇_递归结构
递归结构递归是一种常见的解决问题的方法,即把问题逐渐简单化。递归的基本思想就是“自己调用自己”,一个使用递归技术的方法将会直接或者间接的调用自己。​利用递归可以用简单的程序来解决一些复杂的问题。比如:斐波那契数列的计算、汉诺塔、快排等问题。​递归结构包括两个部分:​1.定义递归头。解答:什么
为什么mysql不推荐使用雪花ID作为主键
作者:毛辰飞背景在mysql中设计表的时候,mysql官方推荐不要使用uuid或者不连续不重复的雪花id(long形且唯一),而是推荐连续自增的主键id,官方的推荐是auto_increment,那么为什么不建议采用uuid,使用uuid究
Python进阶者 Python进阶者
9个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这