我使用下面的查询来查询laravel中的随机行数。
Select * from table order by rand() limit 0,1000
我的数据表分页大小是100,但当我在查询中使用limit时,分页不能正常工作。
如何在服务器端分页的laravel中使用上述查询来实现这一点?
谢谢!
您应该在查询结果后尝试进行分页,因为Laravel会自动添加限制。将以下代码添加到您的模型中:
public function getPaginatorResults($pagination) {
$total = $this->getTotal();
$query = $this->orderByRaw('rand()')
->skip($pagination * ('Paginator::getCurrentPage() - 1))
->take($pagination);
$results = $query->get();
return 'Paginator::make($results->all(), $total, $pagination);
}