需求是根据传入的部门id查询此部门下所有的子部门和子部门的子部门
部门表名称是sys_dept
部门id是dept_id
传入的部门id是#{deptId}
查询完之后返回部门id
拿到sql后只要替换对应的变量就可以了
SELECT
dept_id
FROM
(
SELECT
@ids AS _ids,
( SELECT @ids := GROUP_CONCAT( dept_id ) FROM sys_dept WHERE FIND_IN_SET( parent_id, @ids ) ) AS cids,
@l := @l + 1 AS LEVEL
FROM
sys_dept,
( SELECT @ids := #{deptId}, @l := 0 ) b
WHERE
@ids IS NOT NULL
) id,
sys_dept DATA
WHERE
FIND_IN_SET( DATA.dept_id, ID._ids )
ORDER BY
LEVEL,
dept_id