下面是这个关系
hasMany手推车belongsTo乘积->价格下面是Model类
//# TransactionModel
public function getCarts(){
return $this->hasMany(CartModel::class, 'transaction_id','id');
}
//# CartModel
public function getProduct(){
return $this->belongsTo(ProductModel::class,'product_id','id');
}我想实现的是获得当前transactions(many)的总价格
我现在所做的仍然是迭代每一次转换并用$total对价格进行求和。
Class TransactionModel{
public static function getTotalPrice($transactions){
$total = 0;
foreach($transactions as $transaction){
$total += $transaction->getCarts->sum('getProduct.price');
}
return $total;
}如何在雄辩的代码中做到这一点谢谢
发布于 2019-03-12 10:51:20
我终于找到了一种更好的方法来减少收藏,而不是外汇。
$totalPrice = $transactions->reduce(function($carry, $current){
return $carry + $current->getCarts->sum('getProduct.price');
},0);发布于 2019-02-24 11:26:39
我认为这应该是可行的:
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');
}
}https://stackoverflow.com/questions/54849544
复制相似问题