mysql 查询树状结构数据
当遇到带有父级-子级关系的数据时,例如带有 id、parent_id 和 name 字段的表,并希望根据 name 模糊查询相关层级,就可以使用闭包表来解决。
闭包表
闭包表是一种特殊类型的表,它存储了所有节点及其到根节点的距离。使用闭包表进行模糊查询的主要步骤如下:
示例
假设有一个树状数据如下:
----食物 ---- 水果 ---- 香蕉 ---- 苹果 ---- 肉类 ---- 鸡肉 ---- 肥牛
若要查询包含 "肉" 的所有节点,则可以使用以下查询:
select * from tree where self like '%肉%';
查询结果如下:
+------+---------+----------+ | self | parent | distance | +------+---------+----------+ | 肉类 | 肉类 | 0 | | 肉类 | 食物 | 1 | | 鸡肉 | 鸡肉 | 0 | | 鸡肉 | 肉类 | 1 | | 鸡肉 | 食物 | 2 | +------+--------+----------+
接下来,可以通过分组和合并的方式,将查询到的节点组装成树结构:
from_datebase = [ ["鸡肉", "鸡肉", 0], ["鸡肉", "肉类", 1], ["鸡肉", "食物", 2], ["肉类", "肉类", 0], ["肉类", "食物", 1], ] from itertools import groupby root = {} for _, path in groupby(from_datebase, key=lambda x: x[0]): path = sorted(list(path), key=lambda x: -x[2]) node = root for _, nodename, _ in path: node = node.setdefault(nodename, {})
最终结果如下:
{'食物': {'肉类': {'鸡肉': {}}}}
其他注意事项
以上就是如何使用闭包表高效查询带有父子关系的树状结构数据?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号