我有一个项目的问题,我需要复制一些行,但不是在数据库中,我需要做之后做一个选择查询,我试图做一个代码在该方法找到了模型后,但我认为分页确实工作后,发现我是对的?所以当我尝试修改包含我的结果,订单丢失的阵列和永远不会再工作......我的代码是这样的......CakePHP afterFind和分页顺序不起作用
public function afterFind($results) {
foreach ($results as $rKey = $result) {
if (count ($result['Address']) 1) {
foreach ($result['Address'] as $address) {
$res[] = array('Client' => $result['Client'],
'Address' => $address
);
unset($results[$rKey]);
}
}
}
return $res;
}
所以,这是给有分页的问题.. 。有人能帮我吗??谢谢...
修订
在模型:
公共$为了=阵列( 'Cliente.is_anunciante'=> 'DESC', 'Cliente.nome_fantasia'=>' ASC');
public function paginate(
$conditions, $fields, $order, $limit, $page = 1,
$recursive = null, $extra = array()
) {
$results = $this->getResults($conditions, $fields, $order, $limit, $page, $recursive, $extra);
return $results;
}
public function paginateCount($conditions = null, $recursive = 0, $extra = array()) {
$results = $this->getResults($conditions, $recursive, $extra, null, null, null, null);
return count($results);
}
public function getResults($conditions, $fields, $order, $limit, $page, $recursive, $extra) {
if(!empty($page))
$results = $this->find('all', compact('conditions', 'fields', 'order', 'limit', 'page', 'recursive', 'group'));
if(empty($page))
$results = $this->find('all', compact('conditions', 'recursive', 'extra'));
foreach ($results as $rKey => $result) {
if(!empty($result['Endereco']) && count($result['Endereco']) > 1 && $result['Cliente']['is_anunciante'] != 2){
foreach ($result['Endereco'] as $key => $endereco) {
$results[] = array(
'Cliente' => $result['Cliente'],
'Endereco' => array(
$endereco
)
);
}
unset($results[$rKey]);
}
}
return $results;
}
在控制器的动作里面:
$this->paginate = array(
'limit' => 20,
'order' => array(
'is_anunciante' => 'DESC',
'nome_fantasia' => 'ASC'
)
);
它的原因是paginateCount方法不知道你要添加多少行,使用patryate和paginateCount方法覆盖它们。 – 2014-09-11 03:03:11
如果页面为空,那么'$ limit'是什么? – 2014-09-18 03:07:18