具有laravel查询限制的数据表服务器端分页


Data-table server-side pagination with laravel query limit

我使用下面的查询来查询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);
}