laravel сумма Records.records.record.column в красноречивом - PullRequest
0 голосов
/ 24 февраля 2019

Вот отношение

  1. Транзакция hasMany Тележки
  2. Корзина belongsTo Товар
  3. Товар -> Цена

вот класс модели

//# TransactionModel
public function getCarts(){
    return $this->hasMany(CartModel::class, 'transaction_id','id');
}
//# CartModel
public function getProduct(){
    return $this->belongsTo(ProductModel::class,'product_id','id');
}

чего я хочу добиться, так это получить общую цену текущей транзакции s (много)

, что я сейчас делаюпо-прежнему повторяемся за переход и суммируем цену в $total

 Class TransactionModel{
 public static function getTotalPrice($transactions){
    $total = 0;
    foreach($transactions as $transaction){
            $total += $transaction->getCarts->sum('getProduct.price');
    }
    return $total;
 }

как это сделать в красноречивом коде благодаря

Ответы [ 2 ]

0 голосов
/ 12 марта 2019

я наконец нашел лучший способ с уменьшением сбора вместо foreach

 $totalPrice = $transactions->reduce(function($carry, $current){
                    return $carry + $current->getCarts->sum('getProduct.price');
               },0);
0 голосов
/ 24 февраля 2019

Я думаю, что это должно работать:

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');
    }

}
...