是否可以在刀片视图中使用groupBy在laravel中进行分页?

时间:2019-09-10 22:14:00

标签: php laravel-5 eloquent

我正在获取视图中多个部分的记录。为了显示完整的数据,我只是在做 $data = Data::all();

然后简单地根据需要获取每个部分的计数。 例如:

{{count($data->where('status', 'HOLD'))}}

对于同一视图的其他部分,我想使用Groupy显示结果 例如:

@foreach($data->paginate()->groupBy('user_id') as $byUser)
@endforeach

然后显示分页 {{$data->links()}}

我已经尝试过在控制器中分离结果并使用不同的方法调用数据。

$data = Data::all();
$userData = Data:paginate(5)->groupBy('user_id');
return view('data.all', compact('data', 'userData'));

在没有分页的情况下运行良好。添加分页后,我得到的错误低于此值。

Method Illuminate\Database\Eloquent\Collection::paginate does not exist. (View: C:\xampp\htdocs\project\resources\views\data\all.blade.php)

有什么办法可以解决吗?谢谢。

1 个答案:

答案 0 :(得分:0)

检查此行:

$data = Data::all();

这里您已经在执行查询,这意味着将返回一个Collection实例。这就是为什么您不能使用paginate()方法的原因,因为那是QueryBuilder方法。

尝试一下:

$userData = Data::groupBy('user_id')->paginate(5);

return view('data.all', compact('data', 'userData'));