【问题标题】:Laravel withSum of two columns with additional where clauseLaravel withSum of two columns with Additional where 子句
【发布时间】:2021-09-28 21:17:45
【问题描述】:

我在 Warehouse 和 Sale 模型之间有一对多的关系

仓库.php

public function sales () {
    return $this->hasMany(Sale::class);
}

sales 表有product_pricequantitystatus 列。

我想根据状态栏计算product_price * quantity

如果状态等于 1,则为 sum += product_price * quantity,如果为 2,则为 sum-=product_price * quantity

状态基本上是告诉产品是发货还是退货

我尝试使用withSum 来做到这一点,但我似乎没有成功。我想知道是否有人对此有解决方案。

【问题讨论】:

    标签: laravel eloquent


    【解决方案1】:

    您可以在从 Warehouse 获取所有相关的 sales 后在集合级别执行此操作,如下所示:

    $sales = $warehouse->sales()->select([
      'id', 'product_price', 'quantity', 'status'
    ])->get();
    
    $sum = 0;
    
    $sales->each(function($sale) use(&$sum) {
        $amount = $sale->product_price * $sale->quantity;
        $sale->status == 1 ? $sum += $amount : $sum -= $amount;
    });
    
    

    【讨论】:

    【解决方案2】:
    $wharehouse = Warehouse::findOrFail($warehouse_id)->with('sales')->first();
    $sum = 0;
    foreach($wharehouse->sales as $sale){
       $amount = $sale->product_price * $sale->quantity;
       $sale->status == 1 ? $sum += $amount : $sum -= $amount;
    }
    return $sum;
    

    【讨论】:

    • 请解释一下?
    • 首先,你得到想要的仓库和销售额,然后你循环相关的销售额来得到每个(product_price * quantity)的总和,如果状态=1,否则“包括status = 2" 它将从总和中减去它,然后它将返回金额的最终总和
    • @Tomatoes 谢谢,但我想获得一个带有 sum 属性的仓库集合
    猜你喜欢
    • 2022-12-02
    • 2022-12-01
    • 2015-05-24
    • 2013-05-24
    • 2010-11-16
    • 2022-12-02
    • 1970-01-01
    • 2020-04-28
    • 1970-01-01
    相关资源
    最近更新 更多