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

MySQL数据库中,如何实现递归查询树形结构查询?_第1张图片

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);

查看插入后数据:

MySQL数据库中,如何实现递归查询树形结构查询?_第2张图片

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

比如我们要查询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字段将显示节点的名称。

扩展知识:

MySQL数据库中,如何实现递归查询树形结构查询?_第3张图片

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

你可能感兴趣的:(数据库,mysql)