1

我有一个emp表如下:

userID varchar(10)
ManagerID varchar(10)

数据:

UserID    ManagerID
101         102
103         102
104         103

我需要直接或间接找到经理下的所有用户。

输出应如下所示:

如果是102:

Manager     ReportingUsers
--------------------------
102           101,103         

如果我们检查 104,输出应该是:

Manager     ReportingUsers
--------------------------
104         102,101,103 `

我为实现此目的而编写的查询如下

SELECT managerID, GROUP_CONCAT(userID) FROM emp GROUP BY managerID;

但是我得到的输出满足第一个输出但不满足第二个:

+-----------+----------------------+
| MANAGERID | GROUP_CONCAT(USERID) |
+-----------+----------------------+
| 102       | 101,103              |
| 104       | 102                  |
+-----------+----------------------+

我如何使用游标和存储过程来实现这个用例,通过它我可以获得每个经理的输出?

只是更新如果我使用以下查询,我也会得到第二个示例的结果,但 102 的第一个示例不满意:

SELECT m.MANAGERID,  GROUP_CONCAT(m.USERID,';',(Select Group_Concat(n.USERID) from emp as n where m.userID=n.managerID or n.managerID=NULL group by n.managerID)) as ReportingUsers FROM emp as m GROUP BY managerID;

如果我可以使用游标和过程获得解决方案,那也可以。

4

2 回答 2

0

您可能会考虑切换到嵌套集模型:

user_id lft rgt
    102   1   8
    101   2   3
    103   4   7
    104   5   6

否则,请确认您使用的是哪个数据库/版本。

于 2019-09-27T11:59:16.240 回答
0

您的查询是正确的,它给出了预期的输出:

mysql> select * from testdb.hierarchy;
+--------+-----------+
| userID | managerID |
+--------+-----------+
| 101    | 102       |
| 103    | 102       |
| 104    | 103       |
+--------+-----------+
3 rows in set (0.00 sec)

mysql> select managerID, group_concat(userID) from hierarchy group by managerID ;
+-----------+----------------------+
| managerID | group_concat(userID) |
+-----------+----------------------+
| 102       | 101,103              |
| 103       | 104                  |
+-----------+----------------------+
2 rows in set (0.00 sec)
于 2019-09-27T11:32:42.050 回答