laravel сумма Records.records.record.column в красноречивом
Вот отношение
- сделка
hasMany
Тележки - телега
belongsTo
товар - товар
->
цена
вот класс модель
//# TransactionModel
public function getCarts(){
return $this->hasMany(CartModel::class, 'transaction_id','id');
}
//# CartModel
public function getProduct(){
return $this->belongsTo(ProductModel::class,'product_id','id');
}
чего я хочу добиться, так это получить общую стоимость текущей транзакции (много)
то, что я делаю сейчас, все еще повторяется за переход и суммирует цену в $total
Class TransactionModel{
public static function getTotalPrice($transactions){
$total = 0;
foreach($transactions as $transaction){
$total += $transaction->getCarts->sum('getProduct.price');
}
return $total;
}
как это в красноречивом коде спасибо
1 ответ
Я наконец нашел лучший способ уменьшить коллекцию вместо foreach
$totalPrice = $transactions->reduce(function($carry, $current){
return $carry + $current->getCarts->sum('getProduct.price');
},0);
Я думаю, что это должно работать:
Class TransactionModel{
public function getTotalPrice(){
return $this->getCarts()->withCount([
'getProduct' => function($q){
return $q->select(DB::raw("SUM(price) as price_sum"));
}
])->get()->sum('getProduct_count');
}
}