mysql5.7分类表组成树
时间: 2023-06-30 08:15:57 浏览: 97
MySQL 5.7中可以使用递归CTE(WITH RECURSIVE)来将分类数据转换为树形结构。假设你有一个分类表categories,包含以下字段:id、name、parent_id,其中parent_id表示该分类的父级分类的id。可以使用以下SQL语句将分类表组成树:
```
WITH RECURSIVE category_tree AS (
SELECT id, name, parent_id, 0 AS level
FROM categories
WHERE parent_id IS NULL
UNION ALL
SELECT c.id, c.name, c.parent_id, ct.level + 1
FROM categories c
JOIN category_tree ct ON c.parent_id = ct.id
)
SELECT * FROM category_tree;
```
这个SQL语句中,使用了递归CTE来递归查询categories表,将分类数据转换为树形结构。其中,第一个SELECT子句查询根节点,即parent_id为NULL的分类。第二个SELECT子句递归查询每个分类的子节点,直到查询到所有子节点为止。最后的SELECT查询将递归查询结果返回。
如果你需要按照树形结构展示分类数据,可以使用ORDER BY子句对level和id进行排序,如下所示:
```
WITH RECURSIVE category_tree AS (
SELECT id, name, parent_id, 0 AS level
FROM categories
WHERE parent_id IS NULL
UNION ALL
SELECT c.id, c.name, c.parent_id, ct.level + 1
FROM categories c
JOIN category_tree ct ON c.parent_id = ct.id
)
SELECT id, name, parent_id, level
FROM category_tree
ORDER BY level, id;
```
这个SQL语句将分类数据按照树形结构展示,并按照层级和id进行排序。
阅读全文