首页
学习
活动
专区
圈层
工具
发布

Mysql实现树形递归查询

最近在做项目迁移,Oracle版本的迁到Mysql版本,遇到有些oracle的函数,mysql并没有,所以就只好想自定义函数或者找到替换函数的方法进行改造。...Oracle递归查询 oracle实现递归查询的话,就可以使用start with … connect by connect by递归查询基本语法是: select 1 from 表格 start with...pid就是这条记录的根节点了 具体可以参考我以前写的一篇oracle方面的博客:https://cloud.tencent.com/developer/article/1384471 Oracle方面的实现...递归查询 下面主要介绍Mysql方面的实现,Mysql并没有提供类似函数,所以只能通过自定义函数实现,网上很多这种资料,不过已经不知道那篇是原创了,这篇博客写的不错,https://www.2cto.com.../database/201209/152513.html, 下面我也是用作者提供的方法实现自己的,先感谢作者的分享 这里借用作者提供的自定义函数,再加上Find_in_set函数 find_in_set

5.8K30

MySQL实现树形递归查询

最近在做项目迁移,Oracle版本的迁到MySQL版本,遇到有些Oracle的函数,MySQL并没有,所以就只好想自定义函数或者找到替换函数的方法进行改造。...Oracle递归查询 oracle实现递归查询的话,就可以使用start with ... connect by connect by递归查询基本语法是: select 1 from 表格 start...pid,就表示pid就是这条记录的根节点了 具体可以参考前一篇Oracle方面的文章:https://www.linuxidc.com/Linux/2019-03/157225.htm Oracle方面的实现...递归查询  下面主要介绍Mysql方面的实现,Mysql并没有提供类似函数,所以只能通过自定义函数实现,网上很多这种资料,不过已经不知道那篇是原创了,这篇博客写的不错,https://www.2cto.com.../database/201209/152513.html, 下面我也是用作者提供的方法实现自己的,先感谢作者的分享 这里借用作者提供的自定义函数,再加上Find_in_set函数 find_in_set

1.9K00
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mysql省市区递归查询_mysql 递归查询

    递归查询父节点 和子节点 包含mysql 递归查询父节点 和子节点 mysql递归查询,查父集合,查子集合 查子集合 –drop FUNCTION `getChildList` CREATE FUNCTION...`getChi … MySQL递归查询_函数语法检查_GROUP_CONCAT组合结果集的使用 1-前言: 在Mysql使用递归查询是很不方便的,不像Sqlserver...在My … MySQL递归查询树状表的子节点、父节点具体实现 mysql版本(5.5.6等等)尚未支持循环递归查询,和sqlserver.oracle相比,mysql难于在树状表中层层遍历的子节点.本程序重点参考了下面的资料...,写了两个sql存储过程,子节点查询算 … 递归的实际业务场景之MySQL 递归查询 喜欢就点个赞呗!...查询函数即可实现根据一个节点查询所有的子节点,根据一个子节点查询所有的父节点.对于数据 … mysql 递归查询 主要是对于层级关系的查询 最近遇到了一个问题,在mysql中如何完成节点下的所有节点或节点上的所有父节点的查询

    12.3K20

    mysql递归查询

    父子查询: 根据父 id 查询下面所有子节点数据;子父查询: 根据子 id 查询上面所有父节点数据;...————mysql递归查询 目录结构: 创建表并添加测试数据 创建表 添加数据 根据父id递归查询所有子节点 创建函数 根据函数查询 根据子id递归查询所有父节点 写sql语句 根据组织机构名称模糊查询所有父节点...INSERT INTO vrv_org_tab VALUES (‘17’, ‘上海linkdd项目组’, ‘4’, ‘9’); select * from vrv_org_tab; 根据父id递归查询所有子节点...根据子id递归查询所有父节点 根据子id查询父节点就不那么麻烦了,不需要写递归函数,当然,你也可以写递归函数来查询。...注意:只支持单个查询,意思是不可以根据两个或者两个以上的子节点同时查询出所有父节点。我们可以看到,上面参数都是单个值进行递归查询的。

    3.6K41

    Mysql系列之实现树形递归查询

    最近在做项目迁移,Oracle版本的迁到Mysql版本,遇到有些oracle的函数,mysql并没有,所以就只好想自定义函数或者找到替换函数的方法进行改造。...Oracle递归查询 oracle实现递归查询的话,就可以使用start with … connect by connect by递归查询基本语法是: select 1 from 表格 start with...就是这条记录的根节点了 具体可以参考我以前写的一篇oracle方面的博客:https://blog.csdn.net/u014427391/article/details/84996259 Oracle方面的实现...递归查询 下面主要介绍Mysql方面的实现,Mysql并没有提供类似函数,所以只能通过自定义函数实现,网上很多这种资料,不过已经不知道那篇是原创了,这篇博客写的不错,https://www.2cto.com.../database/201209/152513.html, 下面我也是用作者提供的方法实现自己的,先感谢作者的分享 这里借用作者提供的自定义函数,再加上Find_in_set函数 find_in_set

    92630

    MySQL 如何实现递归查询?「建议收藏」

    前言 最近在做的业务场景涉及到了数据库的递归查询。我们公司用的 Oracle ,众所周知,Oracle 自带有递归查询的功能,所以实现起来特别简单。...但是,我记得 MySQL 是没有递归查询功能的,那 MySQL 中应该怎么实现呢? 于是,就有了这篇文章。...函数 MySQL 自定义函数 手动实现 MySQL 递归查询 Oracle 递归查询 在 Oracle 中是通过 start with connect by prior 语法来实现递归查询的...而向上递归,需要包括当前节点及其第一代子节点。 MySQL 递归查询 可以看到,Oracle 实现递归查询非常的方便。但是,在 MySQL 中并没有帮我们处理,因此需要我们自己手动实现递归查询。...(这里没有用到 group by 分组字段,则可以认为只有一组) MySQL 自定义函数,实现递归查询 可以发现以上已经把字符串拼接的问题也解决了。那么,问题就变成怎样构造有递归关系的字符串了。

    12K10

    MySQL递归查询 三种实现方式

    感觉阅读麻烦的伙伴可以直接下载资源:点我下载 目录 1.建表脚本 1.1.建表 1.2.插入数据 2.递归查询三种实现方式 2.1. 方式一 创建自定义函数实现递归查询 注意: 2.1.1....方式三 MySQL 8.0 版本以上 使用 WITH RECURSIVE 实现递归 注意: 2.3.1.查询子节点 含自己 2.3.2.查询子节点 不含自己 2.3.3.查询父节点 含自己 2.3.4...方式一 创建自定义函数实现递归查询 注意: 1.创建函数的时候,可能会报错。...方式二 单纯使用sql 不创建函数 实现递归 注意: 写法比较复杂,但是适合MySQL各版本,比较灵活。...方式三 MySQL 8.0 版本以上 使用 WITH RECURSIVE 实现递归 注意: 写法比较简单,也比较灵活,但是只适用于MySQL8.0及以上版本,这种写法其实和 PostgreSQL

    11.8K20

    MySQL 递归查询实践总结

    MySQL复杂查询使用实例 By:授客 表结构设计 SELECT id, `name`, parent_id FROM `tb_testcase_suite` ?...则表示该记录不存在父级记录,否则表示该记录存在父级记录(假设parent_id值为5,则父级记录id为5),暂且把该记录自身称之为子记录,父级及父父级的记录称之为祖先记录,子级及子子级记录称之为后辈记录 查询需求...1) 根据指定记录的id,查询该记录关联的所有祖先记录,并按层级返回祖先记录name 2) 根据指定parent_id,查询其关联的的所有后辈记录id 查询实现 通过函数调用实现 1)根据指定记录的id...,查询该记录关联的所有祖先记录,并按层级返回祖先记录name # 向下递归 DROP FUNCTION IF EXISTS queryChildrenSuiteIds; DELIMITER ;; CREATE...2)根据指定parent_id,查询其关联的的所有后辈记录id # 向上递归 DROP FUNCTION IF EXISTS querySuitePath; DELIMITER ;; CREATE FUNCTION

    2K40

    mysql递归查询方法|mysql递归查询遇到的坑,教你们解决办法

    1.前言 大家在用mysql递归查询的时候,肯定或多或少的会碰到一些问题,像小编就遇到了天大的坑(如下图),于是自己踩了坑,我得想办法把它铺一铺吖,避免大家也同时遇到这样的问题。...相信很多人都用不惯mysql,小编也是,oracle的递归查询很简单。...就一句sql就可以搞定,还有不清楚或者突然忘记需要温习的小伙伴们,大家可以看小编发的以前的关于oracle递归查询的方法,戳这里:【oracle递归查询方法介绍】 ---- 2.踩坑介绍 mysql递归查询...递归方法之前一定要把这篇文章看完,因为你不看的话,等一下你一执行递归查询语句,一试一个错 3.埋坑教程 我就以这篇文章为例了:https://blog.csdn.net/jian_c/article/details...4.总结 上面这些,就是小编在用mysql递归查询遇到的坑,如果你还没有遇到,恭喜你,看完这篇文章可以避免踩坑了,但是记得点个赞吖。哈哈哈哈哈。

    1.6K20

    递归查询

    ------------------------------------------------------------------------ Start with...Connect By子句递归查询一般用于一个表维护树形结构的应用...''',''''1''''); INSERT INTO TBL_TEST(ID,NAME,PID) VALUES(''''5'''',''''121'''',''''2''''); 从Root往树末梢递归...pid = id MSSQL ---------------------------------------------------------------------------------- 使用递归公用表表达式显示递归的多个级别...使用递归公用表表达式显示递归的两个级别。 以下示例显示经理以及向经理报告的雇员。将返回的级别数目被限制为两个。...使用递归公用表表达式显示层次列表 以下示例在示例 C 的基础上添加经理和雇员的名称,以及他们各自的头衔。通过缩进各个级别,突出显示经理和雇员的层次结构。

    1.2K40

    探索MySQL递归查询:处理层次结构数据

    MySQL的递归查询功能通过公用表表达式(CTE)为处理这类数据提供了便捷的方式。递归查询可以用于管理组织结构、目录树等数据,使您能够轻松地查询任意节点的子节点、父节点或整个路径。 1....MySQL5.7中的实现 在 MySQL 5.7 中,递归查询不支持使用公用表表达式(CTE),而是通过使用用户定义变量(User-Defined Variables)和自连接(Self Join...虽然这种方法比较繁琐,但仍然可以实现递归查询。...递归查询原理与使用场景 递归查询通过迭代处理分层数据的结果集来实现。在我们的案例中,初始查询选择了顶级领导,递归查询则利用较小层级结果,通过连接操作找到下一层级的员工,持续迭代直至到达最底层。...递归查询在实际应用中还能快速准确地分析和查找复杂层级数据关系,提升数据处理效率和准确性。 希望这篇文章能帮助您了解MySQL中的递归查询,以及如何利用这一功能处理层次结构数据。

    1.8K10

    PostgreSQL=>递归查询

    where条件(e3.id=e2.parent_id) ,取虚拟表的ID和实体表parent_id连     这个条件决定了当前递归查询的查询方式(向上查询还是向下查询);   =>第三行的递归开始查询不可缺少...好了,一个简单的递归查询就成了,嗯。。。,如需求同学说:我需要将每条记录的递归结构(path)和层级(depath)的顺序都显示出来。   ...SQL来看,答案其实很简单,在递归完成后将存在子记录的用where条件过滤掉即可(见查询语句最后一行) 嗯,以上几个例子全部是向下递归查询,下面我展示下向上查询的语句,很简单=> 1 with RECURSIVE...,关键,关键是=>第5行的where条件,很意外吧,如此小的改动就有查询方向上的变化,个人对此的理解是:  =>递归向下查询是用虚拟表的id去联结递归表的parent_id   =>递归向上查询是用虚拟表的...~ 最后,需要说明的是,在公司业务满足的情况下尽可能用单层查询语句查询,尤其对于层级较少较固定的结构下较为合适,此建议主要针对的是递归的两大问题而言:  1>递归的查询效率较低,尤其是记录较多层级庞大的记录

    1.1K30

    PostgreSQL=>递归查询

    where条件(e3.id=e2.parent_id) ,取虚拟表的ID和实体表parent_id连     这个条件决定了当前递归查询的查询方式(向上查询还是向下查询);   =>第三行的递归开始查询不可缺少...好了,一个简单的递归查询就成了,嗯。。。,如需求同学说:我需要将每条记录的递归结构(path)和层级(depath)的顺序都显示出来。   ...SQL来看,答案其实很简单,在递归完成后将存在子记录的用where条件过滤掉即可(见查询语句最后一行) 嗯,以上几个例子全部是向下递归查询,下面我展示下向上查询的语句,很简单=> 1 with RECURSIVE...,关键,关键是=>第5行的where条件,很意外吧,如此小的改动就有查询方向上的变化,个人对此的理解是:  =>递归向下查询是用虚拟表的id去联结递归表的parent_id   =>递归向上查询是用虚拟表的...~ 最后,需要说明的是,在公司业务满足的情况下尽可能用单层查询语句查询,尤其对于层级较少较固定的结构下较为合适,此建议主要针对的是递归的两大问题而言:  1>递归的查询效率较低,尤其是记录较多层级庞大的记录

    2.1K50
    领券