mysql怎么查找递归 sql实现mysql递归查询

Mysql8.0递归函数一般比较普遍的就是四种方法:(具体见 SQL Anti-patterns这本书)
因为不支持递归查询,所以Mysql官方当时推荐的是第三种方式:Nested Sets 。我是用过的,非常难受 。现在支持递归查询,我们可以使用第一种 。
其实我还用了一种,一列维持顺序,一列维持层级,有空可以把实现写出来看看 。
英文好的朋友请移步到这里: Managing Hierarchical Data in MySQL Using the Adjacency List Model,不好的同学跟我一起来 。
直接语句说明:
好,就这些吧 。我是姜友华,下次见 。
mysql查询一个表,实现递归查询给mysql怎么查找递归你个网上写mysql怎么查找递归的比较好的例子mysql怎么查找递归:
方法一mysql怎么查找递归:利用函数来得到所有子节点号 。
创建一个function
getChildLst,
得到一个由所有子节点号组成的字符串.
mysql
delimiter
//
mysql
mysql
CREATE
FUNCTION
`getChildLst`(rootId
INT)
-
RETURNS
varchar(1000)
-
BEGIN
-
DECLARE
sTemp
VARCHAR(1000);
-
DECLARE
sTempChd
VARCHAR(1000);
-
-
SET
sTemp
=
'$';
-
SET
sTempChd
=cast(rootId
as
CHAR);
-
-
WHILE
sTempChd
is
not
null
DO
-
SET
sTemp
=
concat(sTemp,',',sTempChd);
-
SELECT
group_concat(id)
INTO
sTempChd
FROM
treeNodes
where
FIND_IN_SET(pid,sTempChd)0;
-
END
WHILE;
-
RETURN
sTemp;
-
END
-
//
Query
OK,
rows
affected
(0.00
sec)
mysql
mysql
delimiter
;
使用mysql怎么查找递归我们直接利用find_in_set函数配合这个getChildlst来查找
mysql
select
getChildLst(1);
+-----------------+
|
getChildLst(1)
|
+-----------------+
|
$,1,2,3,4,5,6,7
|
+-----------------+
1
row
in
set
(0.00
sec)
mysql
select
*
from
treeNodes
-
where
FIND_IN_SET(id,
getChildLst(1));
+----+----------+------+
|
id
|
nodename
|
pid
|
+----+----------+------+
|
1
|
A
|
|
|
2
|
B
|
1
|
|
3
|
C
|
1
|
|
4
|
D
|
2
|
|
5
|
E
|
2
|
|
6
|
F
|
3
|
|
7
|
G
|
6
|
+----+----------+------+
7
rows
in
set
(0.01
sec)
mysql
select
*
from
treeNodes
-
where
FIND_IN_SET(id,
getChildLst(3));
+----+----------+------+
|
id
|
nodename
|
pid
|
+----+----------+------+
|
3
|
C
|
1
|
|
6
|
F
|
3
|
|
7
|
G
|
6
|
+----+----------+------+
3
rows
in
set
(0.01
sec)
mysql中的递归调用 首先创建一个熟悉的机构表
插入几条测试数据:
union all上面的是初始化语句,只会执行一次,查到了 开发部 这一行记录 。
接下来下面的join会用初始化的语句去原来的organization表去join获取所有 开发部的子部门 ,然后再用这些 子部门 去join更下面的部门 。