我正在开发一个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'));