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 思否

相关推荐
wangqiaowq2 小时前
MSSQLSERVER 和 SQLEXPRESS 是 SQL Server 中两种不同类型的实例名称
sql
盒马coding3 小时前
深度解密MySQL2PG工具MySQL至PostgreSQL语法全景拆解过程
数据库·mysql·postgresql
Nandeska3 小时前
13、MySQL半同步复制示例
数据库·mysql
液态不合群3 小时前
【面试题】MySQL 中 count(*)、count(1) 和 count(字段名) 有什么区别?
android·数据库·mysql
怣503 小时前
MySQL聚合函数在查询中的五大核心应用
数据库·mysql
hai74254 小时前
在 Eclipse 的 JSP 项目中引入 MySQL 驱动
java·mysql·eclipse
Amarantine、沐风倩✨5 小时前
一次线上性能事故的处理复盘:从 SQL 到扩容的工程化思路
java·数据库·sql·oracle
千寻技术帮5 小时前
10334_基于Web的文学书刊服务平台
mysql·ssm·源码·代码·文学书刊
l1t5 小时前
用SQL执行累计值汇总的几种方法
数据库·sql·postgresql·duckdb
DarkAthena7 小时前
【GaussDB】排查创建索引后查询数据行数发生变化的问题
数据库·sql·gaussdb