我有两个表格,问题和答案。问题表与答案表有关联。
当在第一页上分页 Eloquent 结果时,它返回 7 个未回答的问题(带有空的关联),以及 3 个已回答的问题,但我需要它返回总共 10 个问题中有 5 个带答案和 5 个没有答案。
现在我正在这样做:
Question::with(['user', 'answers])->paginate(10);
有没有办法始终返回5个已回答/5个未回答,而不是随机的?
我有两个表格,问题和答案。问题表与答案表有关联。
当在第一页上分页 Eloquent 结果时,它返回 7 个未回答的问题(带有空的关联),以及 3 个已回答的问题,但我需要它返回总共 10 个问题中有 5 个带答案和 5 个没有答案。
现在我正在这样做:
Question::with(['user', 'answers])->paginate(10);
paginate()
方法返回一个LengthAwarePaginator对象,因此您可以按照文档中的建议创建自己的分页器。也许(我没有测试过),您可以像这样做:
$limit = $request->input('limit', 5);
$page = $request->input('page', 1);
$total = Question::count();
$offset = ($page - 1) * $limit;
$items1 = Question::with(['user', 'answers'])->has('answers')->limit($limit)->offset($offset)->get();
$items2 = Question::with(['user', 'answers'])->doesntHave('answers')->limit($limit)->offset($offset)->get();
$paginator = new \Illuminate\Pagination\LengthAwarePaginator(
$items1->concat(items2),
$total,
$limit,
$page,
['path' => $request->getPathInfo()]
);
return response()->json($paginator);