在 MySQL 中,可以使用递归公共表达式 (Recursive Common Table Expressions, CTE) 来实现递归查询。递归 CTE 允许我们对具有层次结构或递归关联的数据进行查询。要在 MySQL 中使用 UNTIL
实现递归查询,你需要创建一个递归 CTE,并在其中定义终止条件(UNTIL
)。
以下是一个示例,展示了如何在 MySQL 中使用递归 CTE 和 UNTIL
来实现递归查询:
WITH RECURSIVE category_cte (id, name, parent_id, depth) AS ( -- 基本查询(非递归部分) SELECT id, name, parent_id, 1 as depth FROM categories WHERE parent_id IS NULL UNION ALL -- 递归查询(递归部分) SELECT c.id, c.name, c.parent_id, cte.depth + 1 as depth FROM categories c JOIN category_cte cte ON c.parent_id = cte.id -- 终止条件(UNTIL) WHERE c.parent_id IS NOT NULL ) SELECT * FROM category_cte;
在这个示例中,我们创建了一个名为 category_cte
的递归 CTE,用于查询类别数据。基本查询(非递归部分)从根类别(即 parent_id
为 NULL 的类别)开始。递归查询(递归部分)通过将子类别与父类别关联在一起来获取子类别。终止条件(UNTIL
)是确保不会无限递归地查询所有子类别。
请注意,这个示例仅适用于 MySQL 8.0 及更高版本,因为早期版本不支持递归 CTE。如果你使用的是早期版本的 MySQL,你可能需要使用其他方法(如存储过程、自定义函数等)来实现递归查询。