zoukankan      html  css  js  c++  java
  • mysql函数递归

    我记得oracle,sql server等可以直接在sql语句上递归,但mysql却没有

    换一种思路,用函数递归

    DROP FUNCTION IF EXISTS findOrgan;//DROP是删除这个表
    CREATE FUNCTION findOrgan//5(areaId VARCHAR(255)//1)
    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(OR_ID)//2 INTO sTempChd FROM sys_organ//3 WHERE FIND_IN_SET(PARENT_ID//4,sTempChd)>0;
    END WHILE;
    RETURN sTemp;
    END;

    这是查询某组织节点及它下属所有节点,

    1.这是输入参数的类型

    2.这是组织表组织id

    3这是组织表

    4这是组织表父级id

    5这是你要定义的函数名

    我用的是navicat,点击运行之后就可以看到

    接下来我们测试一下

    查询了所有的组织id为1的下属id(包括自身)

    SELECT OR_ID from sys_organ where FIND_IN_SET(OR_ID,findOrgan(1))

    这是数据库查询组织id为1的下属id,示例如下

    那么用这些id也就可以查到我们想要的数据了

  • 相关阅读:
    Longest Common Substring
    未完成 Anagrams
    strStr
    vim的学习笔记
    Compare Strings
    Two Strings Are Anagrams
    KMP算法
    [ 力扣活动0314 ] 300. 最长上升子序列
    [ 力扣活动0317 ] 1160. 拼写单词
    [ 力扣活动0313 ] 169. 多数元素
  • 原文地址:https://www.cnblogs.com/magepi/p/10184097.html
Copyright © 2011-2022 走看看