我有一个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;
如果我可以使用游标和过程获得解决方案,那也可以。