如何在cakephp中对自定义查询结果进行分页

前端之家收集整理的这篇文章主要介绍了如何在cakephp中对自定义查询结果进行分页前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我正在开发一个cakePHP项目,并且正在开发cakePHP.正如标题中所提到的,我需要对mysql查询的结果集进行分页,以便在视图中显示它们.

通过这种方式,我可以对“Asin”模型的结果进行分页.

$this->paginate =array('Asin'=>array(
            'fields' => array('sku','fnsku'),'conditions' => $marketplace,'page' => 1,'limit' => 20,'order' => array('Asin.asin' => 'asc')
        )
$data = $this->paginate('Asin',$criteria);

我还需要一种方法来对以下查询的结果集进行分页.

$resultset = $this->Asin->query("SELECT * FROM products INNER JOIN asins ON products.id=asins.id ORDER BY products.id");

我该如何添加分页

最佳答案
CakePHP使用两种方法来管理分页查询,即paginate和paginateCount,它们分别用于获取页面数据和总记录数.要使分页自定义查询一起使用,我们需要在我们的模型文件中实现上述功能,您希望在这些功能中使用分页来处理自定义查询.

public function paginate($conditions,$fields,$order,$limit,$page = 1,$recursive = null,$extra = array()) {    
    $recursive = -1;

    // Mandatory to have
    $this->useTable = false;
    $sql = '';

    $sql .= "Your custom query here just do not include limit portion";

    // Adding LIMIT Clause
    $sql .= (($page - 1) * $limit) . ',' . $limit;

    $results = $this->query($sql);

    return $results;
}

….

public function paginateCount($conditions = null,$recursive = 0,$extra = array()) {

    $sql = '';

    $sql .= "Your custom query here just do not include limit portion";

    $this->recursive = $recursive;

    $results = $this->query($sql);

    return count($results);
}

最后在控制器动作中

// Do not forgot to set this,not sure why
$this->Asin->recursive = 0;

// Setting up paging parameters
$this->paginate = array('Asin'=>array('limit'=>5));

// Getting paginated result based on page #
$this->set('userData',$this->paginate('Asin'));

猜你在找的MySQL相关文章