mysql查询上下级机构的方法实例

吾爱主题 阅读:173 2024-04-01 23:24:57 评论:0

前言

查询上下级机构,这个功能可能会在日常工作中遇到,如果使用的oracle数据库,那就很简单,只需要使用oracle提供的层级查询即可实现。如果使用的mysql数据库,那么就需要自己实现这个功能。下面就介绍mysql实现上下级机构查询。

思路:

  • 自定义mysql方法
  • 利用mysql中的【FIND_IN_SET】【group_concat】两个方法

(1)准备测试数据表

?
1 2 3 4 5 6 CREATE TABLE `org_test` (    `org_no` varchar (32) NOT NULL COMMENT '机构编号' ,    `org_name` varchar (200) NOT NULL COMMENT '机构名称' ,    `p_org_no` varchar (32) DEFAULT NULL COMMENT '上级机构编号' ,    PRIMARY KEY (`org_no`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;

测试数据

?
1 2 3 4 5 6 INSERT INTO `org_test` VALUES ( '1001' , '福建省' , null ); INSERT INTO `org_test` VALUES ( '100101' , '厦门市' , '1001' ); INSERT INTO `org_test` VALUES ( '10010101' , '思明区' , '100101' ); INSERT INTO `org_test` VALUES ( '10010102' , '湖里区' , '100101' ); INSERT INTO `org_test` VALUES ( '10010103' , '同安区' , '100101' ); INSERT INTO `org_test` VALUES ( '100102' , '福州市' , '1001' );

(2)查询指定机构的所有下级机构(包括自身)

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 delimiter $$ CREATE FUNCTION getOrgChild (orgNo varchar (32)) RETURNS varchar (1000) CHARSET utf8 BEGIN      -- 定义临时变量      DECLARE tmpOrg varchar (1000) DEFAULT '' ;      -- 循环查询,orgNo不为空,则循环      WHILE orgNo IS NOT NULL DO          -- 拼接所有查询结果          IF tmpOrg = '' THEN              SET tmpOrg = CONCAT(tmpOrg, orgNo);          ELSE              SET tmpOrg = CONCAT(tmpOrg, ',' , orgNo);          END IF;          -- 查询数据          SELECT group_concat(org_no) INTO orgNo FROM org_test WHERE FIND_IN_SET(p_org_no, orgNo) > 0;      END WHILE;           -- 返回结果      RETURN tmpOrg; END $$

测试结果:

(3)查询指定机构的所有上级机构(包括自身)

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 delimiter $$ CREATE FUNCTION getOrgParent (orgNo varchar (32)) RETURNS varchar (1000) CHARSET utf8 BEGIN      -- 定义临时变量      DECLARE tmpOrg varchar (1000) DEFAULT '' ;      -- 循环查询,orgNo不为空,则循环      WHILE orgNo IS NOT NULL DO          -- 拼接所有查询结果          IF tmpOrg = '' THEN              SET tmpOrg = CONCAT(tmpOrg, orgNo);          ELSE              SET tmpOrg = CONCAT(tmpOrg, ',' , orgNo);          END IF;          -- 查询数据          SELECT group_concat(p_org_no) INTO orgNo FROM org_test WHERE FIND_IN_SET(org_no, orgNo) > 0;      END WHILE;           -- 返回结果      RETURN tmpOrg; END $$

测试结果:

总结

到此这篇关于mysql查询上下级机构的文章就介绍到这了,更多相关mysql查询上下级机构内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/qq_39826207/article/details/122024608

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容