京公网安备 11010802034615号
经营许可证编号:京B2-20210330
树形结构数据是一种常见的数据结构,它由节点和边组成,可以用来表示层次化的关系。在MySQL表中存储树形结构数据,可以使用多种方法,本文将简要介绍几种主要的方法。
我们可以使用以下表格来存储此树形结构:
dept_id | name | parent_id
--------|----------------------|----------
1 | 公司 | NULL
2 | 技术部 | 1
3 | 开发团队 | 2
4 | 测试团队 | 2
5 | 销售部 | 1
6 | 区域销售团队 | 5
7 | 在线销售团队 | 5
其中,dept_id 是节点的唯一标识符,name 是节点名称,parent_id 是父节点的 dept_id。如果一个节点没有父节点,则其 parent_id 值为 NULL。
优点:邻接列表模型是非常简单和直观的模型,易于理解和实现。 缺点:查询复杂度高,特别是递归查询。
dept_id | name | path
--------|----------------------|---------
1 | 公司 | 1
2 | 技术部 | 1/2
3 | 开发团队 | 1/2/3
4 | 测试团队 | 1/2/4
5 | 销售部 | 1/5
6 | 区域销售团队 | 1/5/6
7 | 在线销售团队 | 1/5/7
在此模型中,每个节点都有一个唯一标识符dept_id,名称name和path,该路径包含其所有祖先节点的dept_id,以斜杠分隔。例如,技术部门的路径为1/2,其祖先为公司(dept_id为1)。
优点:查询效率高,对于子节点查询,只需要使用LIKE操作符即可。 缺点:更新节点时,需要更新其后代节点的路径。
dept_id | name | lft | rgt
--------|----------------------|-----|-----
1 | 公司 | 1 | 14
2 | 技术部 | 2 | 7
3 | 开发团队 | 3 | 4
4 | 测试团队 | 5 | 6
5 | 销售部 | 8 | 13
6 | 区域销售团队 | 9 | 10
7 | 在线销售团队 | 11 | 12
在此模型中,
每个节点都有一个唯一标识符dept_id,名称name,以及左右值lft和rgt。左右值的定义是这样的:假设一个节点有子节点,则其左值是其第一个子节点的左值减1,右值是其最后一个子节点的右值加1。如果一个节点没有子节点,则其左值和右值相等。
优点:查询效率高,递归查询时不需要使用JOIN操作,只需要使用BETWEEN操作即可。 缺点:更新节点时,需要更新许多左右值。
dept_id | name | lft | rgt | depth
--------|---------------------|-----|-----|-------
1 | 公司 | 1 | 14 | 0
2 | 技术部 | 2 | 7 | 1
3 | 开发团队 | 3 | 4 | 2
4 | 测试团队 | 5 | 6 | 2
5 | 销售部 | 8 | 13 | 1
6 | 区域销售团队 | 9 | 10 | 2
7 | 在线销售团队 | 11 | 12 | 2
在此模型中,每个节点都有一个唯一标识符dept_id,名称name,以及左右值lft、右值rgt和深度depth。与嵌套集合模型相比,MPTT模型额外提供了深度值,便于快速计算节点的层次关系。
优点:查询效率高,递归查询时不需要使用JOIN操作,只需要使用BETWEEN操作即可。 缺点:更新节点时,需要更新许多左右值。
总结 以上是几种常见的存储树形结构数据的方法。每种方法都有其优点和缺点,具体应用需根据具体场景而定。对于较深的树形结构,MPTT和嵌套集合模型可能比邻接列表和路径枚举模型更适合。但是,在更新节点时,MPTT和嵌套集合模型需要更新大量的值,因此在频繁更新节点的情况下,邻接列表和路径枚举模型可能更好。
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
【核心关键词】大数据、零售商、消费者、供应链、运营、企业、产品、客户、数据模型、大数据平台、数据开发、系统运维、业务逻 ...
2026-06-26在物流配送、供应链履约、终端供货等业务场景中,送货率是衡量企业履约能力、服务质量、供应链稳定性的核心业务指标,直接关联客 ...
2026-06-26 很多数据分析师精通描述性统计,能熟练计算均值、中位数、标准差,但当被问到“用500个样本如何推断10万用户的真实满意度” ...
2026-06-26在数字化管理与数据化运营体系中,指标是连接原始数据与业务决策的核心载体。零散的原始数据只是无意义的数值堆砌,无法直接反映 ...
2026-06-25在Excel数据汇总、财务统计、业务复盘等日常办公场景中,经常需要完成逐行相乘、整体汇总求和的计算需求,最典型的场景就是:单 ...
2026-06-25 很多数据分析师沉迷于复杂的机器学习算法,却忽略了数据分析最基础也最核心的能力——描述性统计。事实上,80%的商业分析问 ...
2026-06-25【核心关键词】主数据、资产、供应商、现金流、企业、精细化、集团、数字化、中国、数据质量、数据管理、经营管理、地产行业、 ...
2026-06-24在数据分析、假设检验、AB测试、学术研究等统计场景中,显著水平(α)与P值(P-value)是判断统计结果是否具有统计学意义的两个 ...
2026-06-24小李刚入职了一家互联网公司的运营部门。第一次参加业务复盘会,运营主管问了一个看似简单的问题:“这个月新用户留存率下降了5 ...
2026-06-24在数字化转型全面渗透的产业背景下,数据分析已成为互联网、金融、零售、制造等几乎所有行业的核心岗位能力。很多初学者对数据分 ...
2026-06-23在企业并购、股权定价、投融资评估、资产核算等资本市场核心场景中,市场法是应用最广泛、市场认可度最高的企业价值评估方法。传 ...
2026-06-23 许多数据分析师精通Excel函数和SQL查询,但当面对一张上万行的销售明细表,要快速回答“哪个地区销量最高”“哪款产品增长最 ...
2026-06-23【核心关键词】运营、证书、金融、客户、产品、软件、销售额、量化、科技、数据分析、金融行业、证券类软件、业务流程、金融机 ...
2026-06-22在企业方案选型、产品迭代评审、供应商筛选、运营效果复盘等决策场景中,单一指标的优劣判断往往无法支撑科学决策。一套转化效果 ...
2026-06-22 很多数据分析师掌握了Excel函数、会写SQL查询,但当被问到“数据从哪里来”“数据加工有哪些步骤”“如何使用分析工具连接数 ...
2026-06-22【核心关键词】软件、洞察力、大数据、产品、经验、硬件、流量、创新、决策、数据安全、网络安全、数据分析、决策制定、数据挖 ...
2026-06-18在方案选型、效果复盘、产品评估、供应商筛选等各类业务决策场景中,仅凭单一指标下结论往往会陷入 “以偏概全” 的误区。多维度 ...
2026-06-18 很多数据分析师精通Excel单元格操作,但当被问到“表结构数据的基本处理单位是什么”“字段和记录的本质区别”“为什么表结 ...
2026-06-18在数据分析、用户运营与业务增长的工作体系中,漏斗拆解是最基础也最高频的问题定位方法。很多业务场景下,我们只能看到最终的转 ...
2026-06-17在数据库开发、数据清洗与报表统计场景中,数值类型转换为日期是高频刚需操作。业务系统常以 Unix 时间戳、整型日期(如20240617 ...
2026-06-17