有效率地對二維數組的列中的值求和
考慮具有「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中文網其他相關文章!