栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

从节点树获取总和

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

从节点树获取总和

特里

您几乎在正确的轨道上。您几乎偶然发现了将层级数据存储在数据库中的“ LTREE”系统。您只需要进行一些修改。就这样。

您的表可能如下所示:

CREATE TABLE Table1    (`id` int, `parent_id` int, `name` varchar(13),     `path` char(10),     `money` int);

您的数据可能看起来像这样。

(1, 0, 'company 1', '1', 10),(2, 1, 'child 1', '1.1', 10),(3, 2, 'child 2', '1.1.1', 10),(4, 1, 'child 3', '1.2', 10,),(4, 1, 'company 2', '2', 10),(4, 1, 'child 2.1', '2.1', 10)

路径列有助于确定哪个公司是另一个公司的子公司。请注意,您实际上并不需要一

allmoney
列。这是动态生成的。

您如何找到属于第一家公司的所有资金?

select sum(money) from Table1 where path >= '1' and path < '2'

注意,在我们创建的结构中,child1是child2的父级。那么我们如何找到child1的钱呢?

select sum(money) from Table1 where path >= '1.1' and path < '1.2'

只有一个查询,没有递归。

MPTT

另一种流行的获取分层数据的方法是使用修改后的顺序树遍历。多年来,Sitepoint上有一篇出色的文章,它解释了如何使用大量示例代码来完成此工作。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/432760.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号