树形结构数据存储方案(二): 物化路径

6 sec read

前一篇文章介绍了比较简单的邻接列表模式,物化路径其实更加容易理解,其实就是在创建节点时,将节点的完整路径进行记录。以下图为例:

tree

按照Path Enumeration 进行存储后的结果如下:

Path-Enumeration

此种方案借助了unix文件目录的思想,主要时以空间换时间。

查询某一节点下的所有子节点:(以Fruit为例)

如何查询直属子节点?需要采用MySQL的正则表达式查询:

查询任意节点的所有上级:(以Yellow为例):

插入新增数据:

此方案的缺点是树的层级太深有可能会超过PATH字段的长度,所以其能支持的最大深度并非无限的。

如果层级数量是确定的,可以再将所有的列都展开,如下图,比较试用于类似行政区划、生物分类法(界、门、纲、目、科、属、种)这些层级确定的内容。

Multiple-lineage-columns

参考文章:

  • https://communities.bmc.com/docs/DOC-9902
打赏作者
微信支付标点符 wechat qrcode
支付宝标点符 alipay qrcode

Python短文本分类:LibShortText和TextG…

LibShortText LibShortText是一个开源的Python短文本(包括标题、短信、问题、句子等
1 min read

条件随机场(CRF)及CRF++安装使用

CRF简介 CRF是用来标注和划分序列结构数据的概率化结构模型。言下之意,就是对于给定的输出,标识序列Y和观测
10 min read

Python数据可视化之词云wordcloud

Wordcloud是一个生成词云的Python包,可以以词语为基本单位更加直观和艺术的展示文本,呈现效果类似标
2 min read

2 Replies to “树形结构数据存储方案(二): 物化路径”

  1. 博主, 下面这种方式是没有办法获取到上级的

    查询任意节点的所有上级:(以Yellow为例):
    SET @path = (SELECT path FROM pathTree WHERE node_name = ‘Yellow’);
    SELECT * FROM pathTree WHERE @path LIKE CONCAT(path, ‘%’) AND path @path;

发表评论

电子邮件地址不会被公开。 必填项已用*标注