如何使用闭包表优化 MySQL 树状结构数据的层级查询?

2024-11-03 19:39:11 编辑:抖狐科技 来源:摘自互联网

如何使用闭包表优化 mysql 树状结构数据的层级查询?

mysql 查询树状结构数据的优化

要查询树状结构数据的层级,通常需要使用递归或闭包表等方法。

闭包表

建议使用闭包表来优化此查询,其结构如下:

create table tree(
  self int,
  parent int,
  distance int
);

登录后复制

插入示例数据并按 self 分类合并形成树:

from_database = [
    ["鸡肉", "鸡肉", 0],
    ["鸡肉", "肉类", 1],
    ["鸡肉", "食物", 2],
    ["肉类", "肉类", 0],
    ["肉类", "食物", 1],
]
from itertools import groupby

root = {}
for _, path in groupby(from_database, key=lambda x: x[0]):
    path = sorted(list(path), key=lambda x: -x[2])
    node = root
    for _, nodename, _ in path:
        node = node.setdefault(nodename, {})
print(root)  # {'食物': {'肉类': {'鸡肉': {}}}}

登录后复制

查询

使用 like 查询带肉的字段,结果如下:

select * from tree where self like '%肉%';

登录后复制

+------+---------+----------+
| self | parent  | distance |
+------+---------+----------+
| 肉类 | 肉类 | 0 |
| 肉类 | 食物 | 1 |
| 鸡肉 | 鸡肉 | 0 |
| 鸡肉 | 肉类 | 1 |
| 鸡肉 | 食物 | 2 |
+------+--------+----------+

登录后复制

该方法的优点是,它可以非常高效地查询树状结构数据,并且可以很容易地扩展到查询更多层级的层级。

以上就是如何使用闭包表优化 MySQL 树状结构数据的层级查询?的详细内容,更多请关注抖狐科技其它相关文章!

本站文章均为抖狐网站建设摘自权威资料,书籍,或网络原创文章,如有版权纠纷或者违规问题,请即刻联系我们删除,我们欢迎您分享,引用和转载,我们谢绝直接复制和抄袭!感谢...
我们猜你喜欢