前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【MySQL疑难杂症】如何将树形结构存储在数据库中(方案二 Path Enumeration)

【MySQL疑难杂症】如何将树形结构存储在数据库中(方案二 Path Enumeration)

作者头像
弗兰克的猫
发布2018-01-09 14:41:41
3K1
发布2018-01-09 14:41:41
举报
文章被收录于专栏:Java爬坑系列

  今天来介绍把树形结构存入数据库的第二种方法——路径枚举法。

  还是借用上一篇的栗子,为了方便大家查阅,我把图又原样搬过来了。

  需要回答的问题依旧是这样几个:

  1.查询小天的直接上司。

  2.查询老宋管理下的直属员工。

  3.查询小天的所有上司。

  4.查询老王管理的所有员工。

方案二、 Path Enumeration 路径枚举法,记录下根节点到每个子节点的路径。

  先创建表:

代码语言:javascript
复制
CREATE TABLE employees2(
eid INT,
ename VARCHAR(100),
position VARCHAR(100),
path VARCHAR(200)
)

  然后插入数据:

image.png
image.png

  现在我们来回答一下之前的问题:

  1.查询小天的直接上司。

  在上一个解决方案中能轻而易举做到的事情,在这个方案中却有些麻烦了,因为需要对path字段进行字符串处理,去掉“/”+自身id才是直接上司的path值。又开始一顿骚操作:

  SELECT e1.eid,e1.ename FROM employees2 e1,employees2 e2 WHERE e2.ename = '小天' AND e1.path = REPLACE(e2.path,CONCAT('/',e2.eid),'');

  好像这个操作还不够sao,2333,结果如下:

image.png
image.png

  2.查询老宋管理下的直属员工。

  怎么查管理下的直属员工呢?那就要用模糊查询了:

  SELECT e2.eid,e2.ename FROM employees2 e1,employees2 e2 WHERE e1.ename = '老宋' AND e2.path REGEXP CONCAT(e1.path,'/[0-9]{1,}$');

  这里用了正则匹配,匹配所有path符合规则的记录,结果如下:

image.png
image.png

  3.查询小天的所有上司。

  SELECT e1.eid,e1.ename FROM employees2 e1,employees2 e2 WHERE e2.ename='小天' AND e2.path like concat(e1.path,'/%');

  这里就能体现这种存储结构的优势了。不看效率的话,还是很方便的。

image.png
image.png

  4.查询老王管理的所有员工。

  SELECT e2.eid,e2.ename FROM employees2 e1,employees2 e2 WHERE e1.ename='老王' AND e2.path like concat(e1.path,'/%');

  看吧,查起来就so easy了。

image.png
image.png

  不用像之前那样写一大段存储过程了,简单粗暴。

  小结一下,存储路径的方式在进行多级查询的时候十分方便,而在查询直接上下级的时候稍微复杂一点。还有一个很明显的缺点,那就是path的大小是指定的,所以理论上是不能进行无限层级的存储的,path值设置的越大,浪费的空间就越多。

  至此,本篇介绍完毕,之后还会介绍其他方法,欢迎大家继续关注!

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017-12-09 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档