簡體   English   中英

Laravel / Eloquent有很多關系總和()

[英]Laravel / Eloquent hasMany relationship sum()

我無法弄清楚如何急切加載關系列的總和。

數據庫(簡化)如下;

TABLES

PRODUCT       PRODUCT_VARIATIONS
*ID*          *ID*
*NAME*        *NAME*
              *AVAILABLE_STOCK*

我的關系設置如下;

public function variations()
{
    return $this->hasMany('Product_variation');
}

加載所有產品時,我希望能夠看到附加到產品對象本身的該產品的所有庫存的總和。

產品可能有很多變化。

我可以退回產品附帶的所有個人變體(見下文)

$products = Product::with('variations')->paginate(15);

但我只是想用一個簡單的整數返回所有產品,顯示他們的available_stock計數考慮到所有變化。

我希望能夠打字

@foreach ($products as $product)
$product->available_stock  // Returns INT
@endforeach

Eloquent本身不支持關系計數急切加載。

閱讀本文,了解如何自己實現它:

如何獲得hasMany關系有效計數

問題是,你不想要count ,但sum 所以這就是你需要的東西,就像@Joseph鏈接的文章一樣,只有不同的聚合函數:

public function availableStock()
{
    return $this->hasOne('Product_variation')
       ->selectRaw('product_id, sum(available_stock) as aggregate')
       ->groupBy('product_id');
}

public function getaAvilableStockAttribute()
{
    if ( ! array_key_exists('availableStock', $this->relations)) {
       $this->load('availableStock');
    }

    $relation = $this->getRelation('availableStock');

    return ($relation) ? $relation->aggregate : null;
}

然后你可以做你要求的:

$products = Product::with('availableStock')->get();
$products->first()->availableStock; // '155' | null

// or simply
Product::first()->availableStock; // '155' | null

好的,謝謝你的答案@joseph,現在我知道我正在瘋狂追逐。

用一個沒有吸引力的foreach解決了這個問題

$products = Product::with('variations')->remember(2)->paginate(15);
    foreach ($products as $product) {
        $i = 0;
        foreach ($product->variations as $variation)
        {
            $i = $i + $variation->available_stock;
        }
        unset($product->variations);
        $product->available_stock = $i;
    }

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM