出处 https://www.jb51.net/article/242090.htm
递归向上
SELECT
T1.LEVEL,
T2.*
FROM
(
SELECT
@ids AS _id,
( SELECT @ids := parent_id FROM sys_role WHERE role_id = _id ) AS pid,
@l := @l + 1 AS LEVEL
FROM
-- 从@ids往上查(从下往上查)
(SELECT @ids := 4, @l := 0) vars,
sys_role h
WHERE
@ids != 0
) T1
JOIN sys_role T2 ON T1._id = T2.role_id
ORDER BY
T1.LEVEL;
递归向下
SELECT
ID.LEVEL,
DATA.*
FROM
(
SELECT
@ids AS _ids,
( SELECT @ids := GROUP_CONCAT( region_id ) FROM region WHERE FIND_IN_SET(parent_id, @ids ) ) AS cids,
@l := @l + 1 AS LEVEL
FROM
region,
( SELECT @ids := 3, @l := 0 ) b
WHERE
@ids IS NOT NULL
) ID,
region DATA
WHERE
FIND_IN_SET( DATA.region_id, ID._ids )
ORDER BY
LEVEL
--创建测试环境
create table t_test(
id int PRIMARY key,
parent_id int,
name varchar(200)
)
insert t_test VALUES(1,null,"中国");
insert t_test VALUES(2,1,"华北");
insert t_test VALUES(3,2,"山西省");
insert t_test VALUES(4,2,"北京");
insert t_test VALUES(5,3,"临汾市");
insert t_test VALUES(6,4,"北京市");
insert t_test VALUES(7,5,"尧都区");
insert t_test VALUES(8,6,"朝阳区");
insert t_test VALUES(9,7,"解放西路");
insert t_test VALUES(10,8,"朝阳北路");
SELECT * FROM t_test;