Mysql 8.0
在MySQL8.0版本中,可以使用with预警来递归查询树形结构的。
本文来源:凯哥个人博客(kaigejava#com):MySQL数据库中,如何实现递归查询树形结构查询?
1. 定义
WITH 子句是 MySQL 中的一种 SQL 结构,又称为 Common Table Expression (CTE)。它在不影响原有 SQL 语句的情况下,允许开发人员临时创建一个内存中的结果集,然后对其进行操作。
2.用途
WITH 子句的主要用途是创建一个暂时的结果集,这个结果集在后续的查询中可以多次使用。WITH 子句主要用于解决查询复杂度高的问题,因为它可以将多次需要的计算结果集存储下来,以便后续的查询可以直接使用。它还可以帮助我们更好地组织复杂的 SQL 查询,使得代码更加清晰易读。
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 是查询的过滤条件。
创建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字段将显示节点的名称。
更多相关知识👉:凯哥个人博客