首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >雄辩中Records.records.record.column的拉拉和

雄辩中Records.records.record.column的拉拉和
EN

Stack Overflow用户
提问于 2019-02-24 07:02:02
回答 2查看 129关注 0票数 0

下面是这个关系

  1. 事务hasMany手推车
  2. Cart belongsTo乘积
  3. 产品->价格

下面是Model类

代码语言:javascript
复制
//# 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对价格进行求和。

代码语言:javascript
复制
 Class TransactionModel{
 public static function getTotalPrice($transactions){
    $total = 0;
    foreach($transactions as $transaction){
            $total += $transaction->getCarts->sum('getProduct.price');
    }
    return $total;
 }

如何在雄辩的代码中做到这一点谢谢

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-03-12 10:51:20

我终于找到了一种更好的方法来减少收藏,而不是外汇。

代码语言:javascript
复制
 $totalPrice = $transactions->reduce(function($carry, $current){
                    return $carry + $current->getCarts->sum('getProduct.price');
               },0);
票数 0
EN

Stack Overflow用户

发布于 2019-02-24 11:26:39

我认为这应该是可行的:

代码语言:javascript
复制
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');
    }

}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54849544

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档