我正在获取视图中多个部分的记录。为了显示完整的数据,我只是在做
$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)
有什么办法可以解决吗?谢谢。
答案 0 :(得分:0)
检查此行:
$data = Data::all();
这里您已经在执行查询,这意味着将返回一个Collection
实例。这就是为什么您不能使用paginate()
方法的原因,因为那是QueryBuilder
方法。
尝试一下:
$userData = Data::groupBy('user_id')->paginate(5);
return view('data.all', compact('data', 'userData'));