Mysql

关注公众号 jb51net

关闭
首页 > 数据库 > Mysql > mysql WITH RECURSIVE

mysql递归查询语法WITH RECURSIVE的使用

作者:小玉起起

本文主要介绍了mysql递归查询语法WITH RECURSIVE的使用,WITH RECURSIVE用于执行递归查询,特别适合处理层级结构或递归数据,具有一定的参考价值,感兴趣的可以了解一下

WITH RECURSIVE 是 SQL 中用于执行递归查询的语法,特别适合于处理层级结构或递归数据(如树形结构、图结构)。递归查询可以反复引用自己来查询多层次的数据,而无需写多个嵌套查询。

基本语法结构:

WITH RECURSIVE CTE_name AS (
    -- 基础查询部分 (非递归部分)
    SELECT column1, column2, ...
    FROM table_name
    WHERE condition

    UNION ALL

    -- 递归查询部分
    SELECT column1, column2, ...
    FROM table_name t
    JOIN CTE_name cte ON t.column = cte.column
    WHERE condition
)
SELECT * FROM CTE_name;

关键部分解析:

递归查询的工作流程:

示例:员工与经理的层级关系

假设有一个员工表,每个员工有一个 manager_id 字段指向他们的经理,我们希望查询某个员工及其所有上级经理,直到最顶层的经理为止。

WITH RECURSIVE EmployeeHierarchy AS (
    -- 基础查询部分:查找某个特定员工
    SELECT id, name, manager_id
    FROM employees
    WHERE id = :employee_id  -- 查找指定员工

    UNION ALL

    -- 递归查询部分:查找员工的经理
    SELECT e.id, e.name, e.manager_id
    FROM employees e
    JOIN EmployeeHierarchy eh ON e.id = eh.manager_id
)
-- 返回所有员工及其上级经理
SELECT * FROM EmployeeHierarchy;

解释:

示例:树形结构的数据(如分类)

假设有一个包含分类的表 categories,每个分类有一个 parent_id 字段指向其父分类。我们希望查询某个分类及其所有的子分类。

WITH RECURSIVE CategoryHierarchy AS (
    -- 基础查询部分:查找某个特定分类
    SELECT id, name, parent_id
    FROM categories
    WHERE id = :category_id  -- 查找指定分类

    UNION ALL

    -- 递归查询部分:查找分类的子分类
    SELECT c.id, c.name, c.parent_id
    FROM categories c
    JOIN CategoryHierarchy ch ON c.parent_id = ch.id
)
-- 返回所有分类及其子分类
SELECT * FROM CategoryHierarchy;

解释:

递归查询的特性:

总结:

到此这篇关于mysql递归查询语法WITH RECURSIVE的使用 的文章就介绍到这了,更多相关mysql WITH RECURSIVE内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

您可能感兴趣的文章:
阅读全文