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也就可以查到我们想要的数据了

  • 相关阅读:
    minecraft我的世界汇总网站
    扫雷网页版
    扫雷模型(非完全一样)
    设计模式-策略模式
    hadoop(2)hadoop配置
    hadoop(1)入门
    Openssl
    加密解密
    信息安全通信
    Web
  • 原文地址:https://www.cnblogs.com/magepi/p/10184097.html
Copyright © 2011-2022 走看看