我有一个过滤查询,如下所示。
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
获得:此集合实例上不存在属性[数量]。
答案 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();
未测试。