MySQL数据库中,如何实现递归查询树形结构查询?

2023-12-25 14:34:34

Mysql 8.0

在MySQL8.0版本中,可以使用with预警来递归查询树形结构的。

本文来源:凯哥个人博客(kaigejava#com):MySQL数据库中,如何实现递归查询树形结构查询?

一、什么是 WITH 子句

1. 定义

WITH 子句是 MySQL 中的一种 SQL 结构,又称为 Common Table Expression (CTE)。它在不影响原有 SQL 语句的情况下,允许开发人员临时创建一个内存中的结果集,然后对其进行操作。

2.用途

WITH 子句的主要用途是创建一个暂时的结果集,这个结果集在后续的查询中可以多次使用。WITH 子句主要用于解决查询复杂度高的问题,因为它可以将多次需要的计算结果集存储下来,以便后续的查询可以直接使用。它还可以帮助我们更好地组织复杂的 SQL 查询,使得代码更加清晰易读。

二、WITH 子句的语法和用法

1.语法

WITH 子句的语法形式如下:

WITH?cte_name?(column_name1,?column_name2,?...)?AS?(?SELECT?column1,?column2,?...?FROM?table?WHERE?condition?)

说明:其中,cte_name 是 WITH 子句的名称;column_name1、column_name2 等是结果集的列名;SELECT 子句定义了该结果集的内容;condition 是查询的过滤条件。

2.使用示例

创建category表,ging插入示例数据:

CREATE?TABLE?category?(
??id?INT,
??name?VARCHAR(50),
??parent_id?INT
);

INSERT?INTO?category?(id,?name,?parent_id)
VALUES
??(1,?'root',?NULL),
??(2,?'category1',?1),
??(3,?'category2',?1),
??(4,?'category3',?2),
??(5,?'category4',?2),
??(6,?'category5',?3);

查看插入后数据:

使用递归查询来查询树形结构的数据

比如我们要查询parent_id=1的SQL语句如下:

WITH?RECURSIVE?category_tree?AS?(
??SELECT?id,?name,?parent_id,?0?AS?depth
??FROM?category
??WHERE??parent_id??=?1

??UNION?ALL

??SELECT?c.id,?c.name,?c.parent_id?,?p.depth?+?1
??FROM?category?c???

??INNER?JOIN?category_tree?p?ON?c.parent_id?=?p.id
	?WHERE??c.parent_id??=?1
)
SELECT?id,?name,?parent_id,?depth
FROM?category_tree;

查看查询结果 :

以上查询将显示树形结构的所有节点的id、name、parent_id和层级深度(depth)信息。

对于查询结果中的每一行,name字段将显示节点的名称。

扩展知识:

更多相关知识👉:凯哥个人博客

文章来源:https://blog.csdn.net/kaizi_1992/article/details/135197214
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。