Php Laravel Group By和其他列的总和

Php Laravel Group By和其他列的总和,php,laravel,Php,Laravel,我的数据库中有一个表,如下所示: id | date | amount ======================== 1 | 2015-01-26 | 1000 2 | 2015-02-26 | 100 3 | 2014-06-26 | 10 我想按年份对记录进行分组,然后找出每组金额的总和 我可以使用以下查询查找组: Fee::orderBy('date', 'DESC') ->get() ->groupBy(function($date) {

我的数据库中有一个表,如下所示:

id | date       | amount
========================
1  | 2015-01-26 | 1000
2  | 2015-02-26 | 100
3  | 2014-06-26 | 10
我想按年份对记录进行分组,然后找出每组金额的总和

我可以使用以下查询查找组:

Fee::orderBy('date', 'DESC')
  ->get()
  ->groupBy(function($date) {
    return Carbon::parse($date->date)->format('Y'); // grouping by years
})

但是我无法得到每个组的金额总和。

恐怕我现在无法用eloquent计算出来,但这应该适用于查询生成器。对我来说没问题:

DB::table('fees')
    ->select(DB::raw('YEAR(date) as year'), DB::raw('sum(amount) as total'))
    ->groupBy(DB::raw('YEAR(date)') )
    ->get();
使用您在问题中输入的相同日期:

id       date                       amount
 1       2015-01-26                  1000
 2       2015-02-26                  100
 3       2014-06-26                  10
它给出了以下内容:

array:2 [▼
  0 => {#150 ▼
    +"year": 2014
    +"total": "10"
  }
  1 => {#151 ▼
    +"year": 2015
    +"total": "1100"
  }
]

您应该在方法链的末尾调用
->get()
/
->sum('amount')
。试着移动它,让我们知道你是否得到了你需要的。另外,您当前是否得到一些结果或错误?如果你收到一个错误,请分享。@haakym它按年份对结果集进行分组。我意识到这一点。我想问的是,它是否会在原始代码中产生错误,还是会返回一组数据?我想在laravel中进行类似的查询。按我意识到的年份(日期)从费用组中选择id、金额(金额)作为“总金额”。我在问你一个问题:你问题中的代码有效吗?是或否?如果没有,会发生什么:您是收到错误还是收到数据。错误或数据是什么样子的?我应用了你的解决方案,但它给出了一个错误。strtolower()要求参数1为字符串,对象为给定值。但如果give following返回零(0)。费用::orderBy('date','DESC')->get()->groupBy(函数($date){return Carbon::parse($date->date)->format('Y');})->sum('amount');