在 MySQL 中查询组织树通常需要使用递归查询,也称为 "树形查询"。递归查询是指,查询语句会自己递归地调用自己来查询树形结构中的所有节点。
假设你有一张表,名为 "employees",用来存储员工的信息,并且有一个 "manager_id" 列来存储员工的直属经理的员工编号,那么你可以使用以下查询来获取组织树:
WITH RECURSIVE employee_tree AS (SELECT id, name, manager_id
FROM employees
WHERE manager_id IS NULL
UNION ALL
SELECT e.id, e.name, e.manager_id
FROM employees e
INNER JOIN employee_tree et ON e.manager_id = et.id
)
SELECT * FROM employee_tree;
这个查询会递归地查询所有的员工,并将它们组织成一颗树。在这个查询中,第一个 SELECT 语句用来查询组织树的根节点,也就是所有没有直属经理的员工。第二个 SELECT 语句用来查询所有其他的员工,并且将它们与它们的直属经理连接起来。
你也可以通过修改这个查询来调整输出的信息,比如只查询某个员工的直属下属,或者只查询某个部门的员工树。
例如,你可以使用以下查询来获取员工编号为 123 的员工的直