news 2026/5/29 23:30:31

Mysql 8.0+ 的递归查询WITH RECURSIVE

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Mysql 8.0+ 的递归查询WITH RECURSIVE

MySQL with Recursive是一种基于递归思想的MySQL查询方式,可以实现对数据的递归查询和处理,返回符合条件的数据,在MySQL 8.0版本中,该功能被正式引入。

这种递归查询方式用于单表自关联,可以应用在很多场景下,比如对于树形结构、层级结构的数据处理,以及对数据进行分类汇总等。比如在开发中常见的有部门层级查询,省市区结构查询。

一、基本递归语法
WITH recursive r as (
-- 递归基:由此开始递归
select id,parent_id,name from category where id = 1
union ALL
-- 递归步:关联查询
select c.id,c.parent_id,c.name
from category c inner join r
-- r作为父表,c作为子表,所以查询条件是c的parent_id=r.id
where r.id = c.parent_id
)
select id,parent_id,name from r

二、添加层级 path、与树形自关联结构(用部门id联结)

WITH RECURSIVE department_tree (department_id, department_name, parent_department_id, depth, path) AS (
SELECT
department_id,
department_name,
parent_department_id,
1 AS depth,
CAST(department_id AS CHAR(200)) AS path
FROM company_department
WHERE parent_department_id IS NULL
UNION ALL
SELECT
cd.department_id,
cd.department_name,
cd.parent_department_id,
dt.depth + 1 AS depth,
CONCAT(dt.path, ',', cd.department_id) AS path
FROM company_department cd
JOIN department_tree dt ON cd.parent_department_id = dt.department_id
)
SELECT
department_id, department_name, parent_department_id, depth, path
FROM department_tree
ORDER BY path;

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/30 14:24:49

C++ 结构体(struct)【1】

C/C 数组允许定义可存储相同类型数据项的变量,但是结构是 C 中另一种用户自定义的可用的数据类型,它允许您存储不同类型的数据项。结构用于表示一条记录,假设您想要跟踪图书馆中书本的动态,您可能需要跟踪每本书的下列属性&#x…

作者头像 李华
网站建设 2026/5/29 17:25:15

gpt-oss-20b在低资源环境下的性能调优技巧

gpt-oss-20b在低资源环境下的性能调优技巧 在大模型如GPT-4等闭源系统主导云端AI服务的当下,一个现实问题日益凸显:普通开发者、中小企业甚至科研团队难以负担高昂的算力成本和数据隐私风险。尽管这些顶级模型能力强大,但它们往往依赖A100级别…

作者头像 李华
网站建设 2026/5/30 14:26:32

记力扣557.反转字符串中的单词 练习理解

给定一个字符串 s ,你需要反转字符串中每个单词的字符顺序,同时仍保留空格和单词的初始顺序。示例 1:输入:s "Lets take LeetCode contest" 输出:"steL ekat edoCteeL tsetnoc"示例 2:输入&#…

作者头像 李华
网站建设 2026/5/30 14:27:09

将Seed-Coder-8B-Base嵌入VS Code插件的完整开发流程

将Seed-Coder-8B-Base嵌入VS Code插件的完整开发流程 在现代软件开发中,一个常见的矛盾逐渐浮现:我们手握强大的大语言模型,却不得不将代码片段上传到云端才能获得智能补全建议。这对金融、军工或任何重视源码安全的企业来说几乎是不可接受的…

作者头像 李华
网站建设 2026/5/30 14:26:37

提升文生图效率:利用VSCode插件集成FLUX.1-dev开发环境

提升文生图效率:利用VSCode插件集成FLUX.1-dev开发环境 在数字内容创作的前沿战场上,设计师与开发者正面临一个共同挑战:如何让创意从“想到”到“看见”的路径更短、更直观、更可控?传统的文本生成图像工作流往往割裂——写提示词…

作者头像 李华
网站建设 2026/5/30 14:26:34

利用Easy File Sharing Web Server漏洞进行攻击

一、环境准备1、目标机:主机(下载并安装Easy File Sharing Web Server(以下用efs表示))2、攻击机:kali二、信息收集1、下载好的efs打开,用户名和密码不用输入,直接运行2、进入之后可以看到主机开放的端口&a…

作者头像 李华