在本教程中,您将了解MySQL递归CTE(公共表表达式)以及如何使用它来遍历分层数据。
自MySQL 8.0版以来简要介绍了公共表表达式或叫CTE的功能,因此需要您在计算机上安装MySQL 8.0,以便在本教程中练习本语句。
1. MySQL递归CTE简介
递归是一个具有引用CTE名称本身的子查询的CTE。以下说明递归CTE的语法 –
WITH RECURSIVE cte_name AS ( initial_query -- anchor member UNION ALL recursive_query -- recursive member that references to the CTE name ) SELECT * FROM cte_name;
递归CTE由三个主要部分组成:
形成CTE结构的基本结果集的初始查询(initial_query),初始查询部分被称为锚成员。
递归查询部分是引用CTE名称的查询,因此称为递归成员。递归成员由一个或UNION DISTINCT运算符与锚成员相连。
终止条件是当递归成员没有返回任何行时,确保递归停止。
递归CTE的执行顺序如下:
首先,将成员分为两个:锚点和递归成员。
接下来,执行锚成员形成基本结果集(R0),并使用该基本结果集进行下一次迭代。
然后,将Ri结果集作为输入执行递归成员,并将Ri+1作为输出。
之后,重复第三步,直到递归成员返回一个空结果集,换句话说,满足终止条件。
最后,使用UNION ALL运算符将结果集从R0到Rn组合。
2. 递归成员限制
递归成员不能包含以下结构ÿ