mysql怎么查询上下级机构

网友投稿 798 2023-07-05

mysql怎么查询上下级机构

mysql怎么查询上下级机构

思路:

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

(1)准备测试数据表

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;登录后复制

测试数据

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)查询指定机构的所有下级机构(包括自身)

delimiter $$CREATE FUNCTION getOrgChild (orgNo varchar(32)) RETURNS varchar(1000) CHARSET utf8BEGIN -- 定义临时变量 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)查询指定机构的所有上级机构(包括自身)

delimiter $$CREATE FUNCTION getOrgParent (orgNo varchar(32)) RETURNS varchar(1000) CHARSET utf8BEGIN -- 定义临时变量 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 $$登录后复制

测试结果:

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Mysql简易索引方案分析
下一篇:mysql元数据指的是什么
相关文章