Laravel 5.4:groupsBy id和count每个产品的数量

时间:2018-04-30 11:54:42

标签: laravel eloquent laravel-5.4

我有一个过滤查询,如下所示。

public function index( Request $request ) {
        $dateFrom = $request->get( 'dateFrom' );
        $dateTo   = $request->get( 'dateTo' );
        $status   = $request->get( 'orderState' );

        $orders = ( new OrderList() )
            ->whereHas( 'orderDetail', function ( $query ) {
                $query->where( 'supplier_id', Auth::guard( 'supplier' )->user()->id );
            } )
            ->with( 'deliveryList' )
            ->with( 'orderDetail' )
            ->when( $dateFrom, function ( $query ) use ( $dateFrom, $dateTo ) {
                $query->whereBetween( 'created_at', [ $dateFrom, $dateTo ] );
            } )
            ->when( $status, function ( $query ) use ( $status ) {
                $query->where( 'order_state_id', $status )->get();
            } )->get();

        $productList = $orders->orderDetail;
        dd( $productList );
        //Order Status
        $orderStates = OrderState::listsTranslations( 'states' )->pluck( 'states', 'id' )->toArray();


        return view( 'supplierComponents.order_list', compact( 'orders', 'orderStates' ) );
    }

现在此查询将输出包含订单详细信息的订单列表。 我需要的是按顺序对产品进行分组并获得数量

最后一个观点应该是这样的

product name           quantity
-------------------------------
Tea                      5
-------------------------------
juice                    3
-------------------------------

我的模特 OrderLst

public function orderDetail() {
        return $this->hasMany( OrderDetail::class, 'order_id' );
    }

更新 以为我永远不会从controller以正确的方式得到它而且我没有考虑过直接尝试将其放入刀片中

所以我所做的就是转移到试图让它在那里的刀片。

我在这里做了什么

@foreach($orders as $order)
    @foreach($order->orderDetail as $items)
       <tr>
         <td>{!! $items->quantity !!}</td>
         <td>{!! $items->product_name !!}</td>
       </tr>
    @endforeach
@endforeach

现在,我正在根据需要列出所有产品,但尝试Group 像那样

@foreach($orders as $order)
      @foreach($order->orderDetail->groupBy('product_id') as $items)
          <tr>
            <td>{!! $items->quantity !!}</td>
            <td>{!! $items->product_name !!}</td>
          </tr>
      @endforeach
@endforeach
  

获得:此集合实例上不存在属性[数量]。

1 个答案:

答案 0 :(得分:0)

$orders = ( new OrderList() )
        ->whereHas( 'orderDetail', function ( $query ) {
            $query->where( 'supplier_id', Auth::guard( 'supplier' )->user()->id );
        } )
        ->with( 'deliveryList' )
        ->with(['orderDetail' => function ($query) {
                $query->select(DB::raw('*, sum(quantity) as quantity_sum'))->groupBy('product_id')->get();
            }])
        ->when( $dateFrom, function ( $query ) use ( $dateFrom, $dateTo ) {
            $query->whereBetween( 'created_at', [ $dateFrom, $dateTo ] );
        } )
        ->when( $status, function ( $query ) use ( $status ) {
            $query->where( 'order_state_id', $status )->get();
        } )->get();

未测试。