美文网首页
小猿圈之MySql递归查询

小猿圈之MySql递归查询

作者: 小猿圈加加 | 来源:发表于2019-06-10 11:31 被阅读0次

不管学习什么语言,python、java、php等等如果你以后的方向是web,那么你都离不开数据库,mysql数据库又是开源的,所以是最受欢迎的数据库,也是企业用的最多的数据库,小猿圈老师详解mysql的递归查询,不懂的同学可以看过来了。

一、递归语句

-- 向下递归函数

SELECT GROUP_CONCAT('''', pk_dept , '''')  FROM rzzxdb.bi_dept WHERE FIND_IN_SET(fr_pk_dept,'1070')>0;

设置某个部门下的所有子部门为无效:

update bi_dept set zt ='0' WHERE FIND_IN_SET(fr_pk_dept,'部门ID')>0;

二、自定义递归函数

利用find_in_set()函数和group_concat()函数实现递归查询:、

1、向下递归:

调用方式:

SELECT * FROM t_areainfo WHERE FIND_IN_SET(id,queryChildrenAreaInfo(4));

实例:

DROP FUNCTION IF EXISTS queryChildrenAreaInfo;

CREATE FUNCTION queryChildrenAreaInfo(areaId INT) -- 或者 areaId char

RETURNS VARCHAR(4000)

BEGIN

DECLARE sTemp VARCHAR(4000);

DECLARE sTempChd VARCHAR(4000);

SET sTemp='$';

SET sTempChd = CAST(areaId AS CHAR);

WHILE sTempChd IS NOT NULL DO

SET sTemp= CONCAT(sTemp,',',sTempChd);

SELECT GROUP_CONCAT(id) INTO sTempChd FROM t_areainfo WHERE FIND_IN_SET(parentId,sTempChd)>0;

END WHILE;

RETURN sTemp;

END;

2、向上递归

调用方式:

SELECT * from t_areainfo where FIND_IN_SET(id,queryChildrenAreaInfo1(7));

实例:

DROP FUNCTION IF EXISTS queryChildrenAreaInfo1;

CREATE FUNCTION queryChildrenAreaInfo1(areaId INT)

RETURNS VARCHAR(4000)

BEGIN

DECLARE sTemp VARCHAR(4000);

DECLARE sTempChd VARCHAR(4000);

SET sTemp='$';

SET sTempChd = CAST(areaId AS CHAR);

SET sTemp = CONCAT(sTemp,',',sTempChd);

SELECT parentId INTO sTempChd FROM t_areainfo WHERE id = sTempChd;

WHILE sTempChd <> 0 DO

SET sTemp = CONCAT(sTemp,',',sTempChd);

SELECT parentId INTO sTempChd FROM t_areainfo WHERE id = sTempChd;

END WHILE;

RETURN sTemp;

END;

mysql递归方式分为向上递归和向下递归,小猿圈老师详解的mysql递归就到这了,想必大家看后有所了解了,学明白的同学感觉收获满满,有问题的朋友可以去小猿圈看看老师的视频详解,也许看后你会更加深入的了解。

相关文章

  • MySQL

    mysql递归查询组织机构mysql 递归查询 MySQL教程之concat以及group_concat的用法 M...

  • mysql实现递归查询

    mysql中没有提供递归查询的语句,我们通过mysql函数实现这种查询。 对于如下一张表privilege,递归查...

  • 教你如何使用 MySQL8 递归

    之前写过一篇 MySQL通过自定义函数的方式,递归查询树结构,从MySQL 8.0 开始终于支持了递归查询的语法 ...

  • 【MySQL】递归查询上下级

    环境 需要MySQL8.0+ 上下级关系图 建表语句 查询上下级sql语句 递归,查询本级以及所有下级 递归,查询...

  • Mysql递归查询

    ms sqlserver数据库,支持with as 语法中直接递归调用。但mysql并不支持with as 语法,...

  • mysql递归查询

    在项目中会遇到同一个表中保存着父子关系的数据,最常见的就是处理树形结构资源。下面举个简单的例子,先看一下表: 然后...

  • mysql递归查询

    表如上: 调动语句:

  • (十七)MySQL递归查询

    表定义 测试数据 递归查询指定父节点下面的所有子节点数据 获取pid=‘ROOT’的所有节点及下级节点 获取所在层...

  • MYSQL 递归查询示例

  • 递归的实际业务场景之MySQL 递归查询

    喜欢就点个赞呗!源码<--请点击此处查看 引入 当我看到一些评论时,例如下面的样子。我挺好奇这个功能是怎么样做出来...

网友评论

      本文标题:小猿圈之MySql递归查询

      本文链接:https://www.haomeiwen.com/subject/jsbffctx.html