程序问答   发布时间:2022-06-02  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了从节点树获取总和大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如何解决从节点树获取总和?

开发过程中遇到从节点树获取总和的问题如何解决?下面主要结合日常开发的经验,给出你关于从节点树获取总和的解决方法建议,希望对你解决从节点树获取总和有所启发或帮助;

特里

您几乎在正确的轨道上。您几乎偶然发现了将层级数据存储在数据库中的“ 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'

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

@H_175_2@mPTT

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

解决方法

我正在学习php。我有这个结构

company 1 - $10| all $50
-company 1.1 - $10| all $20
--company 1.1.1 - 10$| all $10
-company 1.2 - $20| all $20

每个公司可能有几个子公司,可能只有一个母公司。每个公司都有钱。所有公司都有Allmoney-自己的钱+他所有子公司的钱。

在MySQL中这样的结构

id|parent_id|name|money|allmoney
1| 0| company 1| 10|###
2| 1| company 1.1|10 |###
3| 2| company 1.1.1|10 |###
4| 1| company 1.2|10 |###

因此,我如何计算每个公司在php中的allmoney?我现在需要使用递归,但是我尝试了并且没有任何反应。选择,更新和其他命令mysql-
我知道,请使用php帮助我。我写这样的东西:

function updatemoney($id)
    {
        $data = CS50::query("SELECT ...",$id);
        $allmoney = 0;

        if(count($data) > 0)
        {
            foreach($data as $row)
            {

                $allmoney += $row["cash"];
               //somewhere this,maybe need ubdate my db 
                $allmoney += updatemoney($row["id"]);
            }
        }
        else return 0;
    }

非常感谢你

大佬总结

以上是大佬教程为你收集整理的从节点树获取总和全部内容,希望文章能够帮你解决从节点树获取总和所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。