首页 >后端开发 >php教程 >如何在 PHP 中有效地对二维数组列中的值求和?

如何在 PHP 中有效地对二维数组列中的值求和?

Barbara Streisand
Barbara Streisand原创
2024-12-14 05:08:14591浏览

How Can I Efficiently Sum the Values in a 2D Array's Column in PHP?

高效地对二维数组的列中的值求和

考虑具有“f_count”和“uid”字段的用户数据数组。要在不使用 foreach 循环的情况下对“f_count”列中的值求和,以下技术提供了有效的解决方案:

在 PHP 版本 5.5 中,利用 array_column() 和 array_sum() 函数,它们提供了一个优雅的解决方案:

$value = array_sum(array_column($arr, 'f_count'));

PHP 5.4 及更高版本的另一种有效方法是将 array_reduce() 与匿名函数结合使用函数:

$value = array_reduce($arr, function ($carry, $item) {
    return $carry + $item['f_count'];
}, 0);

两种技术都避免了迭代循环,从而提高了性能。

或者,修改数据库查询以返回扁平数组也可以消除进一步处理的需要:

$query = "SELECT SUM(f_count) AS total_f_count FROM users WHERE gid=:gid";

此查询将返回包含 f_counts 总和的单行,呈现后续的数组操作没有必要。

以上是如何在 PHP 中有效地对二维数组列中的值求和?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn