MySQL 初探递归查询

为什么需要这玩意?

Q: 那递归查询相比一般的查询有什么不同呢?

A: 可以查树形结构(自引用),比如一部门中还有一个子部门,如果要查这个部门中所有的部门,传统查询比较难搞。

要MySQL 8.0 +

先上语法:

SQL 复制代码
WITH RECURSIVE cte_name AS
(
    SELECT ...      -- return initial row set
    UNION ALL / UNION DISTINCT
    SELECT ...      -- return additional row sets
)
SELECT * FROM cte;

递归采用CTE(Common Table Expressions,With XXX 就是CTE)实现,再详细地解释下:

组成部分解释:

  1. WITH RECURSIVE:标识这是一个递归的Common Table Expression。

  2. cte_name:为递归查询定义一个临时的名称,用于在后续查询中引用。

  3. (column_list) :列出在递归过程中需要的列名。

  4. 初始化部分(非递归基)

    • SELECT column_list: 选择开始递归时的基本数据,这些通常是层级结构的顶层节点。
    • FROM table: 指定数据来源表。
    • WHERE initial_conditions: 设置初始条件,筛选出递归起点的数据。
  5. UNION ALL:将初始化部分的结果与递归部分的结果合并。

  6. 递归部分(递归步骤)

    • SELECT column_list: 选择在递归过程中需要的列,可能包括从CTE自身引用的列。
    • FROM cte_name: 引用前面定义的CTE名称,表示递归地基于之前计算出的结果继续查询。
    • JOIN table ON recursion_conditions: 使用JOIN操作将CTE与原始表或其他相关表连接起来,根据递归条件确定下一层级的数据。
  7. 最后的SELECT * FROM cte_name:从构建好的递归CTE中选择所有数据作为最终查询结果。

举个例子

上图是departments表,能看出,parent_department_id就是一个自引用字段,引的是ID。 我们的SQL语句如下:

sql 复制代码
WITH RECURSIVE departments_list as
(
SELECT departments.id,departments.department_name,departments.parent_department_id from departments WHERE id = 1
UNION ALL
SELECT d1.id,d1.department_name,d1.parent_department_id from departments d1 inner join departments_list d2 on d1.parent_department_id = d2.id
)
SELECT * FROM departments_list;

我写下来,我感觉要注意的几个问题一定要搞明白:

  1. Q:就是departments_list的字段是怎么确定的? A:是第一个子SQL的Select字段决定的。
  2. Q:怎么才算结束?A:第二个子SQL查不到值了。

参考文档:

教你如何使用 MySQL8 递归 - Java开发指北 - SegmentFault 思否

相关推荐
麻雀无能为力6 分钟前
CAU数据库class2 SQL语言
数据库·sql·oracle
计算机学姐1 小时前
基于SpringBoot的小型民营加油站管理系统
java·vue.js·spring boot·后端·mysql·spring·tomcat
双层木屋1 小时前
使用GoLang版MySQLDiff对比表结构
mysql·golang
枷锁—sha2 小时前
SQL注入——Sqlmap工具使用
数据库·sql·安全·web安全
进击的CJR3 小时前
MySQL 8.0 OCP 英文题库解析(五)
数据库·mysql·开闭原则
付出不多5 小时前
linux——mysql高可用
linux·运维·mysql
昭阳~7 小时前
MySQL读写分离
数据库·mysql
my_styles11 小时前
docker-compose部署项目(springboot服务)以及基础环境(mysql、redis等)ruoyi-ry
spring boot·redis·后端·mysql·spring cloud·docker·容器
冬瓜的编程笔记11 小时前
【八股战神篇】MySQL高频面试题
数据库·mysql·面试
wangzhongyudie12 小时前
SQL实战:06交叉日期打折问题求解
数据库·sql