首页 > 解决方案 > 是否可以在刀片视图中使用 groupBy 在 laravel 中进行分页?

问题描述

我正在获取视图中多个部分的记录。为了显示完整的数据,我只是在做 $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)

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

标签: phplaravel-5eloquent

解决方案


检查这一行:

$data = Data::all();

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

尝试这个:

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

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

推荐阅读